Chapter 1 General 


1.1 System Overview 


The uPD72070 Floppy Disk Controller (FDC) is a new advanced Floppy Disk 
Controller that can support four standard Floppy Disk Drives (FDD)'s and two 
Apple specific FDDs, respectively. For the standard FDDs, the uPD72070 FDC 
is compatible with the NEC wPD765A and therefore maintaining 
compatibility with all uPD765A existing software and copy -protection 
schemes. . 


The uPD72070 FDC has the special capability to support both writing and 
reading the Apple proprietary GCR format. In addition the uPD72070 can 
support conventional MFM and FM formats in the 2DD, 2HD, 2ED and 2TD 
typed FDDs. These features make the uPD72070 FDC easily adaptable into 
Apple Macintosh computers. 


By having the same register set as in the IBM PS/2 and PC/AT computers, the 
uPD72070 FDC can easily be adapted in these PCs and compatible PCs. 


The external circuits necessary to support both Apple Computers standard 
Super Drive FDD's and conventional MFM FDDs are fully implemented into 
the uPD72070 FDC. 


1.2 Features 


The 72070 Advanced Floppy Disk Controller or "New Age FDC" has the 
following features. 


¢ General 
- Functional superset of 1PD765A and Intel 82077 
- Supports Apple GCR format 
- Supports 1MB, 2MB, 4MB and 13MB FDDs 
- Automatic wake up from standby modes Host Interface 
- 8-bit BUS width 
- 16-byte FIFO in the Data register 
- Implements PS/2 and PC/AT registers 
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- Intel Interface 
¢ Drive Interface 
- Supports both the Apple specific FDDs and standard FDDs 
- Analog PLL based on pPD72069 
- Precompensator 
- Clock Generator 
- FDD drivers and receivers 
¢ Additional commands 
- Apple specific commands 
( These should be disclosed only to Apple Computer) 


1.3 Recording Formats 
This FDC can support the following two formats: 


1) GCR recording format used on special FDDs in Apple Macintosh 
Computers 


2) MFM and FM recording formats used on conventional FDDs and Super 
Drives in Apple Macintosh Computers 


1.3.1 GCR Format Description (Group Code Recording) 


GCR is the older of the two floppy disk formats used in Macintosh 
computers. Disks formatted with GCR can store up to 800K bytes on a 
double sided disk. In the GCR encoding scheme, only binary 1's generate 
transitions (Figure 1.3.1). A long run of zeroes, leading to an absence of 
transitions, can make the data recovery process very difficult and 
unreliable. In order to improve the reliability of data recovery, the 
software driver code (referred to as the driver), encodes the data to limit 
the maximum number of non-transitions to 2. Apple calls this process 
nibblizing, and if effectively encodes 3 bits of raw data into 4. When the 
driver reads data from the disk, it decodes it by a process called 
denibblizing. 
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Fig. 1.3.1 GCR Encoded Read and Write Data 


1.3.1.1 GCR Track and Sector Format 


In order to maximize the storage capacity of a GCR floppy disk, GCR drives 
vary their spindle speed by making automatic adjustments based on the 
cylinder. This permits greater storage for the outer cylinders than could be 
achieved if the spindle speed were held constant. As a simplification, the 
80 cylinders on a GCR drive are split up into 5 speed zones, each with a 
different number of formatted sectors(Table 1.3.1). 


Table 1.3.1 GCR Speed Groups 
Speed Zone Cylinders Sectors 


I 0 to 15 12 
2 16 to 31 11 
3 32 to 47 10 
4 48 to 63 9 
5 64 to 79 8 


The driver formats a disk so that the sectors are evenly distributed around 
each track(Figure 1.3.2). This is accomplished by varying the number of 
sync groups between the sectors of the track. A sync group is composed of 
a 6 byte sequence(FF 3F CF F3 FC FF) which guarantees that the hardware 
is synchronized prior to the beginning of an address or data mark. 


During the format process, the driver initially tries to format the track 
with 6 or 7 sync groups between sectors. If that is successful, the driver 
will increment the number of sync groups and reformat the track. If that 
format is successful, the process is repeated until the format fails. Once the 
format has failed, the driver uses the last successful number of sync 
groups to format the track. . 
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Fig. 1.3.2 GCR Track Format 









Figure 1.3.3. shows the GCR sector format. Both parts of the sector begin 
with six self sync bytes. The address field consists of three mark bytes($D5, 
$AA, $96); the track, sector, side, format and checksum bytes(encoded as 
GCR nibbles); and two bit slip bytes (§DE, $AA). The track and side 
information are combined into a 16-bit word that puts the side number 
into bit 11 and the track number into bits 0-10. Although 11 bits are 
specified for the track number, only 8 bits are used. The remaining 3 bits, 
track 10-8, are always 0. 


The data field consists of three mark bytes($D5, $AA, $AD), the sector 
number, sector data, and two bit slip bytes($DE, $AA). The sector data 
consists of: 12 tag bytes (used by the operating system), 512 data bytes 
(containing user data), and 3 checksum bytes. When encoded as GCR 
nibbles, the data tales up 703 bytes:4*[(12+512)/3 groups]=699 data+4 
checksum bytes. 
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Fig. 1.3.3 GCR Sector Format 


1.3.1.2 Nibblizing and Denibblizing 


As mentioned in the previous section, data written to the disk must be 
encoded in order to limit the "0" run length of the serial bit stream. 
When data is written it is nibblized, and when it is read it is denibblized. 
Because of the size of the address field, the driver encodes the data and 
address header differently. The nibblizing and denibblizing processes for 
each will be discussed separately. 


1.3.1.3 Nibblizing Sector Data 


GCR sector data contains two parts: Tag Bytes and Sector Data (see the 
section on GCR sector format for more details). The operating system uses 
the 12 bytes for various functions. While, the sector data merely contains 
512 bytes of user data. Between the two, the total length of the sector data 
field is 524 bytes. Therefore, the driver must nibblize 524 bytes when it 
writes the sector data. 


The nibblizing process(US patent #4,564,941 Wooley et al, Apple 
Computer Inc.) begins by reading 3 bytes of data in order to encode them 
into 4 bytes. The encoding guarantees that the four bytes do not exceed the 
run length restriction of the GCR encoding specification. As a convention, 
the bytes in this 3 byte group are referred to as the A byte, B byte, and C 
byte. 


Nibblizing is performed in a two stage process. In the first stage the driver 
accumulates the checksums for the 3 bytes of data. When computing the 


overall checksum for the data, the driver maintains three checksums; the 
A, B, and C checksum, that correspond to the A, B, and C bytes. The 
algorithm for this is shown below on pseudocode: 


/* Reads Data from the System Memory */ 
For (n=0; n=<0x20b;n++)  /* repeats 524 times */ 


Read( Data(n) ); /* reads data from the System 
Memory into Data (n) */ 
Data(0x20c)=0; /* the only last data should be set to 
zero */ 

/* Initialization */ 

ChecksumA =0 ; 

ChecksumB =0 ; 

ChecksumC =0 ; 


Carry_ChecksumCx =0 ; /*the Carry bit of ChecksumCx */ 
For (n=0; n=< Ox0ae;n++) /* repeats to calculate 175 times */ 
ByteA=Data(n); 
ByteB=Data(n+1); 


ByteC=Data(n+2); 


ChecksumA=ChecksumA + ByteA + Carry_ChecksumCx; 
ByteA =ByteA XOR ChecksumC; 


ChecksumB=ChecksumB + ByteB + Carry_ChecksumA; 
ByteB =ByteB XOR ChecksumA; 


ChecksumCx=ChecksumC + ByteC + Carry_ChecksumB; 
ByteC =ByteC XOR ChecksumB; 


ChecksumC=Rotate Left 1, not through Carry_ChecksumCx; 


It is important to notice in the pseudocode above that there is interaction 


amongst both the checksums and the data. This is done to improve the 
error detection capability of the algorithm. In order to properly encode the 
data, the driver must adhere to this exact sequence of operations. 
Violating the sequence will cause encoding errors. 


In the second stage of the process, the 3 bytes are encoded to limit the "0" 
run length of the data prior to writing in to disk. Fig. 1.3.4 shows the 
second stage of the nibblizing process. 
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Fig. 1.3.4 Nibblizing process for Sector Data 


The driver strips of the two upper bits of each of the three bytes and 
accumulates them in a fourth byte, called the Hi-Bits byte. The driver then 
encodes each of these four bytes with the Nibblizing look up table shown 
in Table 1.3.2. For example, applying the byte $0F(001111 in binary) to the 
table yields an encoded byte of B3H. After the driver encodes each byte, 
they are written to the disk serially, with the most significant bit written 
first. Because the driver computes the checksums prior to the Hi-Bits byte. 


Table 1.3.2 Nibblizing Look-Up Table 


Bits 2:8 
866 6801 O10 811 168 161 118 111 


Bits 
5:3 





The encoding process described above assumes that data portion of the 
sector is evenly divisible by 3. Unfortunately this is not the case. Because 


the sector data field is 512 bytes long, the driver must handle the residual 
2 bytes as a special case. In order to properly encode the last 2 bytes of the 
sector data, the driver assumes that a 513th byte is zero. Therefore, the 
driver encodes that last two bytes assuming a third byte which is zero. The 
driver dose not write this zero byte to the disk. 


After the driver wries that last data to the disk, the driver nibblizes the 
three checksum bytes(as shown in Figure 1.3.4), and writes them to the 
disk. 


13.1.4 Denibblizing 


When the driver reads data from the disk it must be decoded before it can 
be used. Apple calls this process denibblizing. The driver denibblizes the 
read data in two stages. 


In the first stage the driver reads four data bytes from the disk. The driver 
must work in blocks of four bytes because the nibblizing process encoded 
three byres into four. As the bytes are read from the disk, the driver 
initially decodes them with the look-up table in Table 1.3.3. For example, a 
data byte of $B9 is decoded to $14. 


Bits 7:4 


Bits 
3:8 
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Table 1.3.3 Denibblizing look-up table 


After the decode through the look-up table, the data is now composed of 4 
bytes with their two most significant bits to zero. The driver then takes 
the first of the 4 bytes(the Hi-Bits byte) and re-distributes the data, in two 
bit chunks, across the remaining three bytes. Figure 1.3.5 shows the 
complete decoding process. 
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Fig. 1.3.5 Denibblizing process for Sector Data 








Now that the original three have been reassembled, the driver must 
compute and compare the checksums. The pseudocode example below 
shows the algorithm for computing the checksum during a read. 


/* Reads Read-Data from the FDD */ 
For (n=0; n=<0x2bb ; n++) /* repeats 700 */ 
Read{ Byte(n) ); /* reads Read-data from the FDD 
into Data (n) after denibblization */ 
/* Initialization */ 
ChecksumA =0 ; 
ChecksumB =0 ; 
ChecksumC =0; 


For (n=0; n=< Ox0ae;n++) /* repeats to calculate 175 times */ 
Carry_CheksumC =ChecksumC(bit7); 
ChecksumC=Rotate Left 1, not through carry (Checksum(C); 


Byte(n)=Byte(n) XOR ChecksumC; 
ChecksumA=ChecksumA + Byte(n) + Carry_ChecksumC; 


Byte(n+1)=Byte(n+1) XOR ChecksumA; 
ChecksumA=ChecksumA + Byte(n+1) + Carry_ChecksumA; 


Byte(n+2)=Byte(n+2) XOR ChecksumB; 
ChecksumA=ChecksumA + Byte(n+2) + Carry_ChecksumB; 


Data(n) =Byte(n); 
Data(n+1)=Byte(n+1); 
Data(n+2)=Byte(n+2); 


The denibblizing process assumes that the number of bytes the data field 
are evenly divisible by 4. Unfortunately, because of the assumed 513th 
data byte (see the previous section, which was not written when the driver 
encoded the data, there will be a residual of 3 bytes during the read. In 
order to properly decode the last three bytes, the driver assumes a "0" byte 
that is not read from the disk. The driver decodes that last three bytes and 
the assumed "0" byte the same process shown in Figure 1.3.5. 


After the driver has read, decoded, and reassembled all the data bytes, the 
four checksum bytes are denibblized by the same process that is shown in 
Figure 1.3.5. The driver then compares the computed checksum against 
the reassembled three checksum bytes. 


1.3.1.5 Nibblizing and Denibblizing for the Address Header 


Because of the small number of bytes in the address header, the driver 
encodes the address header differently from the data field. In general, the 
process for the address header is much less complicated. As shown in 
Figure 1.3.3, the driver formats the of the address header so that they have 
their upper two bits set to zero, with the data occupying the lower 6bits of 
the byte. This format simplifies the nibblizing process by making the Hi- 
Bits byte process unnecessary. The driver can simply encode the 4 bytes 
directly through the nibblizing table. In addition the checksum 
computation is also significantly simplified. To compute the checksum, 
the driver merely xor's all four bytes into a longitudinal checksum 
according to the following algorithm: 


Checksum : = track byte xor sector byte xor side, track byte xor format byte; 


All four bytes and the checksum byte are then encoded with the look-up 
table in Table 1.3.2 and written to the disk. Figure 1.3.6 shows the 
nibblizing process for the address header and its checksum. 
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Fig. 1.3.6 Address Header Nibblizing Process 


When the driver reads the address header, the driver simply decodes each 
byte with the denibble table shown in Table 2-3. Figure 2-7 shows the 
denibblizing process for the Address header. 
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Fig. 1.3.7 Address Header Denibblizing Process 









From FOD 





The driver then computes and compares the checksum according 
algorithm shown above. 


1.3.1.6 Error Detection for GCR 


The following conditions should be reported as errors: 

e Partial Address Mark 
The address mark found is not complete. 

¢ Bad Address Checksum 
The computed checksum does not match the checksum 
stored at the end of the address header of the sector. 

e Bad Address Bitslip Marks 
The bitslip bytes at the end of the address header do not 
meet the format specification. 

¢ Bad Data Mark 


The data mark of the sector is not complete. 
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¢ Bad Data Checksum 
The computed checksum dose not match the checksum 
stored at the end of the data portion of the sector. 
e Bad Data Bitslip Marks 
The bitslip bytes at the end of the data portion of the 
sector do not meet the format specification. 


1.3.2 MFM Description 


Unlike GCR drivers, MFM drivers do not vary their spindle speed while 
writing or reading data on a disk. Instead, the driver puts the same 
number of sectors on each track. For the 720K format, there are 9 sectors 
per track and for the 1440K format, there are 18 sectors per track. The disk 
drive does vary its spindle speed for the different MFM densities; 600 rpm 
for 720k, or 300 rpm for 1440k. 


1.3.2.1 MFM Track and Sector Format 


Fig. 1.3.2.1 shows the MFM track format The driver uses the index pulse to 
determine where the track physically begins. In order to maintain 
compatibility with the NEC pPD765A disk controller format, the driver 
writes index information during the time that the index pulse is asserted. 
The index field is made up of 12 bytes of zeroes which is followed by the 
index mark. The index mark is composed of three special characters($C2) 
and the byte pattern $FC. These special characters violate the MFM 
encoding standard by missing a transition. Once the index information is 
written is ignored by any subsequent operations. 

physical “I 
Index pulse 
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Index field mark first end of 
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(GAP4A) (12B) (4B) (GAP4A) (GAP4B) 


Fig. 1.3.2.1 MFM Track Format 


Following the index information, the MFM track format contains a gap 
that acts as a buffer to allow for drive variations. Depending on density, 
the driver formats either 9(720K) or 18(1440K) sectors following the gap. 
Following the last sector, the driver writes gap bytes to the end of the track. 
Fig. 1.3.2.2 shows the MFM sector format. 
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Fig. 1.3.2.2 MFM Sector Format 


A track contains 5 distinct gaps that vary depending upon format density. | 
Table 1.3.2.1 shows the gap sizes for all the gaps shown in Figures 1.3.2.1 
and 1.3.2.2, organized according to the disk density. 


Disk Capacity Gap length in Bytes 
Unformatted __ Formatted ___ Gap]_Gap2__Gap3__Gap4A_Gap4B 
IMB 720KB 50 22 84 80 182 
2MB 1.44KB 50 22 101 80 204 
4MB 2.88MB 50 41 83 80 518 


Table 1.3.2.1 Gap sizes for Various MFM disk capacities 


1.3.2.2 CRC Computation for MFM 
The CRC computation for both the address header and sector data follow 
the CCITT-CRC16 algorithm. 


1.3.2.3 Precompensation of MFM Data 


For industry standards, one precompensation value is used with MFM. 
The 1Mbyte and 2Mbyte disks(720K and 1.44M formatted disks) require 
125ns for inner cylinders. The 4MByte disk standard does not require any 
precompensation. The precompensation values are defined by the bits in 
the Data Rate register. 


1.4 Operation Modes 
This FDC can support the following operation modes by using the external 
PCTYP1,0 pins: 


PCTYP1_PCTYPO___ Operation Mode 


1 1 Apple - Selects Active Low Reset 
1 0 General - Standard Mode 
0 0 PS/2 - Standard Mode 
0 1 PC/AT  - Standard Mode 


In each mode, there are different ways available for Registers and 
Commands to be used. Therefore, the host should use the following 
functions according to the operation mode: 
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- Formats - Data rates - Motor On/Off 
- Drive Select - Precompensation 


1.4.1 Apple Mode 


This Apple mode implemented into the uPD72070 FDC is available only 
for Apple Computer and may not be available for other users of this FDC. 


Under Apple mode, only the Status register (STR), Data register (DTR) 
and Data rate register (DRR) can be used. 


GCR recording formats are support on the Macintosh FDD's which include 
the Apple Super Drive and emerging Apple 4MB Super Drive FDD. MFM 
recording formats are supported on 1MB, 2MB, and 4MB FDD's. (There is 
no support for FM recording formats) 


As for the commands, the FDC can support the all commands except the 
following commands: 


- Read Deleted data - Write Deleted data - Scan Equal 
~ Scan Low or Equal - Scan High or Equal - Verify 
- Relative Seek - Dumpreg - Version 


As for the Data Rates, the bits (DRATE1, DRATEO) in the Data Rate 
Register should be set. 


As for the target drive, the bits (DR1, DRO) in the issued commands can 
automatically select the desired drive so that the polling function can be 
supported. 


As for the formats, the (FM) bit in the issued commands can automatically 
select either GCR or MFM formats. 


As for turning the FDD motor On or Off, the Set Motor Control command 
should be used. 


GCR recording requires no preshifting of the Write Data signal from the 
FDC. 
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The Data Register with FIFO will always be available in the Execution 
phase of the Read/Write commands group after the EFO bit and the 


FIFOTHD bits in the Configure command are set. 


The combination of Select Drive Type and Perpendicular Mode commands, 
in conjunction with the setting of the proper bits in the Data Rate Register 


(DRR) register are used to select the types Floppy Disk Drive to be used. 
Selection can be one of the following drives; 2DD, 2HD, 2ED, 2TD and GCR. 
Please refer to Table 1.4.1.2. 


Also, the reference table of various media for different disk capacity, data rate, 
& track number is shown on table 1.4.1.1. 


USA (IBM DOS) 


Media Capacity RPM Data Rate Track (Cylinder) Sector Byte/Sector 


5.25" 1.2M (1.6M) 


3.5" 720K (1M) 
3.5" 1.44M (2M) 
3.5" 2.88M (4M) 
JAPAN 

5.25" 640K 
5.25" 1.2M 

3.5" 640K 

3.5" 1.2M 


Table 1.4.1.1 Capacity, RPM, Data rate, & Track Number 


360 
300 
300 
300 


360 
360 
360 
360 


500K 

250K 

500K 
1M 


300K 
500K 
300K 
500K 


160 (80) 
160 (80) 
160 (80) 
160 (80) 


160 (80) 
154 (77) 
160 (80) 
154 (77) 


15 
9 
18 
36 


co 0c 0 
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512 
o12 
512 
512 
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1024 
512 
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APPLE MODE 


1IMByte (MFM) Horizontal 
2MByte (MFM) Horizontal 
4MByte (MFM) Horizontal 
13MByte(MFM) Horizontal 
1MByte (MFM) Perpendicular 
2MByte (MFM) _ Perpendicular 
4MByte (MFM) Perpendicular 
400K (GCR) Horizontal 
800K (GCR) Horizontal 
400K (GCR) Perpendicular 
800K (GCR) Perpendicular 
PS/2 MODE 
IMByte (MFM) Horizontal 
2MByte (MFM) Horizontal 
4MByte (MFM) Horizontal 
13MByte(MFM) Horizontal 
IMByte (MFM) Perpendicular 
2MByte (MFM) Perpendicular 
4MByte (MFM) Perpendicular 
PC/AT MODE 
1MByte (MFM) Horizontal 
2MByte (MFM) Horizontal 
4MByte (MFM) Horizontal 
13MByte(MFM) Horizontal 
1MByte (MFM) Perpendicular 
2MByte (MFM) Perpendicular 
4MByte (MFM) Perpendicular 
GENERAL MODE 
1MByte (MFM) Horizontal 
2MByte (MFM) Horizontal 
4MByte (MFM) Horizontal 
13MByte(MFM) Horizontal 
1MByte (MEM) Perpendicular 
2MByte (MFM) Perpendicular 
4MByte (MFM) Perpendicular 
400K (GCR) Horizontal 
800K (GCR) Horizontal 
400K (GCR) Perpendicular 
800K (GCR) Perpendicular 
1.4.2 PS/2 Mode 


Table 1.4.1.2. Selecting Floppy Drive Types 
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Under PS/2 mode, all registers, which have the same functions as that in 
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IBM PS/2, are available. The supported formats are MFM and FM 
recording formats to be supported by the world wide standard FDC 
uPD765A. As for the commands, the FDC can support the all commands 
except the following commands, which should be disclosed to Apple 
Computer only: 

- Format/Write -Disable/EnableDPLL _ - Eject Disk 

- Set Drive Mode - Set Motor Control - Raw Dump 


As for the Data Rates, the bits (DRATE1, DRATEO) in the Data Rate 
Register or the bits (DRATE1, DRATEO) in the Configuration Control 
Register should be set. If one register is set and then the other register is 
set, the register that was set last has the priority. 


As for the target drive, the bits (DS1, DSO) in the Digital output Register 
can automatically select the desired drive so that the polling function can 
not be supported. 


As for the formats, the (FM) bit in the issued commands can automatically 
select either FM or MFM formats. 


As for turning the FDD motor On of Off, the bits (EM3, EM2, EM1, EMO) in 
the Digital output Register should be used. 


As for the value of the preshifted Write Data signal, the bits (PCS2, PCS1, 
PCSO0) in the Data Rate Register should be defined and the cylinder to be 
written with the preshifted Write Data signal should be defined by the 
PRETRK bits in the Configure command. The reset default of this PRETRK 
bits is set to the zero so that every cylinder is written with the preshifted 
Write Data signal. 


On the other hand, the Data Register with FIFO can always be available in 
the only Execution phase of the Read/Write commands group after the 
EFO bit and the FIFOTHD bits in the Configure command are set. 


The combination of Select Drive Type and Perpendicular Mode 
commands, in conjunction with the setting of the proper bits in the Data 
Rate Register (DRR) register are used to select the types Floppy Disk Drive 
to be used. Selection can be one of the following drives; 2DD, 2HD, 2ED, 
2TD and GCR. Please refer to Table 1.4.1.2. 


1.4.3 PC/AT Mode 
Under PC/AT mode, the following registers, which have the same 
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functions as that in IBM PC/AT/, are available; 
- Status resister (STR) 
- Data register (DTR) 
- Data Rate Register (DRR) 
- Digital output register (DOR) 
- Digital Input register (DIR) 
- Configuration Control register (CCR) 
- Tape Drive Register (TDR) 
Status A, B register are not available in this mode. 


As for the supported formats, MFM and FM recording formats as same as 
that supported by the world wide standard FDC pPD765A are can be 
supported. 


As for the commands, the FDC can support the all commands except the 
following commands, which should be disclosed to Apple Computer only: 
- Format/Write -Disable/Enable DPLL _ - Eject Disk 
- Set Drive Mode _ - Set Motor Control - Raw Dump 


As for the Data Rates, the bits (DRATE1, DRATEO) in the Data Rate 
Register or the bits (DRATE1, DRATEO) in the Configuration Control 
Register should be set. If one register is set and then the other register is 
set, the register that was set last has the priority. 


As for the target drive, the bits (DS1, DSO) in the Digital output Register 
can automatically select the desired drive so that the polling function can 
not be supported. 


As for the formats, the (FM) bit in the issued commands can automatically 
select either FM or MFM formats. 


As for turning the FDD motor On or Off, the bits (EM3, EM2, EM1, EMO) in 
the Digital output Register should be used. 


As for the value of the preshifted Write Data signal, the bits (PCS2, PCS1, 
PCS0) in the Data Rate Register should be defined and the cylinder to be 
written with the preshifted Write Data signal should be defined by the 
PRETRK bits in the Configure command. The reset default of this PRETRK 
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bits is set to the zero so that every cylinder is written with the preshifted 
Write Data signal. 


On the other hand, the Data Register with FIFO can always be available in 
the only Execution phase of the Read/Write commands group after the 
EFO bit and the FIFOTHD bits in the Configure command are set. 


The combination of Select Drive Type and Perpendicular Mode commands, 
in conjunction with the setting of the proper bits in the Data Rate Register 
(DRR) register are used to select the types Floppy Disk Drive to be used. 
Selection can be one of the following drives; 2DD, 2HD, 2ED, 2TD and GCR. 
Please refer to Table 1.4.1.2. 


1.4.4 General Mode 
Under General mode, the following registers are available: 
- Status resister (STR) 
- Data register (DTR) 
- Data Rate Register (DRR) 
The IBM PS/2 and PC/AT registers are not available. 


As for the supported formats, MFM and FM recording formats as same as 
that supported by the world wide standard FDC pPD765A are can be 
supported. 


As for the commands, the FDC can support the all commands except the 
following commands, which should be disclosed to Apple Computer only: 


- Format/Write - Disable/Enable DPLL - Eject Disk 
- Set Drive Mode - Set Motor Control - Raw Dump 


As for the Data Rates, the bits (DRATE1, DRATEO) in the Data Rate 
Register should be set. 


As for the target drive, the bits (DR1, DRO) in the issued commands can 
automatically select the desired drive so that the polling function can be 
available. 


As for the formats, the (FM) bit in the issued commands can automatically 
select either FM or MFM formats. 
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The control to turn the FDD motor On or Off can not be supported. 


As for the value of the preshifted Write Data signal, the bits (PCS2, PCS1, 
PCS0) in the Data Rate Register should be defined and the cylinder to be 
written with the preshifted Write Data signal should be defined by the 
PRETRK bits in the Configure command. The reset default of this PRETRK 
bits is set to the zero so that every cylinder is written with the preshifted 
Write Data signal. 


On the other hand, the Data Register with FIFO can always be available in 
the only Execution phase of the Read/Write commands group after the 
EFO bit and the FIFOTHD bits in the Configure command are set. 


The Select Capacity command can be used to select the types of drives, 
2DD, 2HD, 2ED, 2TD except GCR. Please refer to Table 1.4.1.2. 


1.5 Data Transfer Modes 


The FDC has the three phases according to the internal operating state in the 
FDC. One is the Command phase to set the required parameter into the FDC, 
second is the Execution phase to be performing the issued command and final 
is the result phase to inform of the host about the result for the executed 
command. 


In these phases, the ways to transfer data between this FDC and the host are 
the following data transfer modes. 


1) DMA transfer mode; 
This transfer mode can be used in the only Execution phase. 
2) Non DMA transfer mode; 


This transfer mode, maybe called as the Programmed I/O mode, can 
be used in all phases but mainly in only Command and Result 
phases. 
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Chapter 2 Pin Functions 
2.1 Host Interface Pins 
[Symbol W/O Signal Function 


RESET In RESET. Sets FDC to idle state. 





XA1,XA2 In CRYSTAL INPUTS. For internal oscillator 
frequency control, a crystal resonator is connected to 
XA1 and XA2. For external clock input at XA1, XA2 
are open. Frequency=24MHz. Supported data 
transfer rates 1Mbps, 500Kbps, 300Kbps and 250Kbps. 


XB In TTL EXTERNAL CLOCK INPUT. 
Frequency =15.6672MHz, for GCR FDD. 
Frequency =20MHz, for 13Mbyte FDD. When 
external clock is not supplied, XB pin must be 
connected to ground. 











CS_b In CHIP SELECT. Validates RD_b and WR_ signals. 
D0-D7 I/O DATA BUS. Bidirectional three-state data bus with 
12mA drive. 

A0-A2 In ADDRESS 0-2. Selects a register in FDC. 

A2 Al AO R/W Register 

0 0 0 R Status Register A (SRA) 

0 0 1. R Status Register B (SRB) 

0 1 0 R/W Digital Output Register (DOR) 

0 1 1 R/W Tape Drive Register(TDR) 

1 0 0 R__ Status Register (STR) 

1 0 0 W Data Rate Register (DRR) 

1 0 1 R/W Data Register with FIFO (DATA) 

1 1 0 - Reserved 

1 1 1 R__ Digital Input Register (DIR) 

1 1 1 W_ Configuration Control register (CCR) 





RD_b 


WR_b 


DMARQ 


DMAAK_b 


TC 


In READ DATA. This Control signal causes the host to 
read data from FDC to the data bus. 


In WRITE DATA. This Control signal causes the host 
to write data from the data bus to the FDC. 


Out DMA REQUEST. Requests data transfer in DMA 
mode. Normally active high, but in PC/AT™ 
Mode,this signal goes to high impedance when the 
D3 bit of DOR is 0. 


In DMA ACKNOWLEDGE .Enables DMA cycle. 
Normally active low, but in PC/AT™ Mode, this 
signal is disabled when the D3 bit of DOR is 0. 


In TERMINAL COUNT. Terminates data transfer.TC 
is accepted only while DMAAK_b is active. TC is 
active high in PC/AT™ Mode and Apple/general 
Mode,and active low in PS/2™ Mode. 


Note: If TC signal is not used as an input signal at 
the completion of the command, the Abnoraml 
Termination will be set (STO = 40) and End of 
Cylinder will be set (STO = 80). Also, see 3.1.9 Status 


Register 0 and 3.1.10 Status Register 1. 


INT 


PCTYPO, 
PCTYP1 


Out INTERRUPT REQUEST. Requests host to process 
transferred data and execution results. Normally 
active high,but in PC/AT™ Mode,this signal goes 
to high impedance when the D3 bit of DOR is 0. 


In PC TYPE PINS. Selects host interface mode. 


PCTYP1 PCTYPO Host I/F Mode I/F Registers 


0 
0 


0 PS/2™ Mode All Registers 

1 PC/AT™ Mode DOR, TDR, 
STR,DRR, 
DATA,CCR 

0 General Mode DATA,STR, DRR 

1 APPLE Mode DATA, STR, DDR 
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2.2 FDD D Interface F Pins as (All aeee have 46mA drive capability) 





DS0-DS3 _b 


Out 


ME0_b,ME1_b Out 


ENBLO_b 
/ME2_b, 

ENBL1_b 
/ME3_b- 


Out 


SEL/HDLD_b Out 


CA0/DIR_b 
CA1/STEP_B 
CA2/SIDE_B 


LSTRB 


Out 


DRIVE SELECT. Selects up to four standard FDDs. 


MOTOR ENABLE. Controls the MFM FDD spindle 
motor on/off ; also can be used as a general-purpose 


DRIVE ENABLE. In Apple mode Enable 0,1 enables 
all communication with the Apple FDD. In other 
modes Motor Enable Controls the MFM FDD 
spindle motor on/off. 


SELECT/HEAD LOAD, CA0/DIR_b, CA1/STEP_b, 
CA2/SIDE_B. Multiplexed signals defined as 
follows: 
In Apple mode: SELECT_B 

COMMAND ADDRESS 0-2 
These lines are used for 2 reasons in Apple Mode: 
1) To multiplex status to RDATA LINE during a 
Read operation, and 2) To select addressable latches 
on the Disk Drive during a command operation. 


In other modes: 
HEAD LOAD. Sets drive head in the load state. 
DIRECTION. Specifies the seek direction. 


DIR _ Direction 
0 ~=Inward 
1 Outward 


STEP PULSE. Generates seek pulses. 
SIDE. Selects double-sided drive head. 


SIDE Drive Head 


0 Head 1 
1 Head 0 


LINE STROBE. In Apple mode, this line is used to 
send a command to the drive. 
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[Symbol VO Signal Function _ 
WDATA_b Out WRITE DATA. Write Data and Clock bits to FDD. 
WGATE_b Out WRITE GATE. Requests FDD to write data. 


WPRT_b (*) In WRITE PROTECT. Indicates medium is write- 
protected. 


RDATA_b In READ DATA. Read data and clock bits from FDD. 


DENO_b (*), Out DENSITY. Specifies the density of a drive that can 

DEN1_b (*) support more than one density. The output is a 
value corresponding to the selected data transfer 
rate. 


INDEX_b (*) In INDEX PULSE. Indicates drive head is positioned at 
physical start point of track on the medium. 


TRKO_b (*) In TRACK 0. Indicates drive head is positioned at 


| cylinder 0. 
DKCG b (*) In DISK CHANGE/READY. Indicates drive status. 
/READY_b (*) ENDKCG DKCG/READY 
0. DKCG 
1 READY 


ENDKCG_b (*) In ENABLE DISK CHANGE. Enables the disk change 
signal (DKCG). 


DRV2_b (*) In DRIVE 2. Indicates whether a second drive is 
installed and is reflected in Status register A (SRA). 


Atte eters Sore ram eT heer Toer ian ery SENSE ESD SALA A ROPE STO PSE SOT AE SHS SSR TY WORE nym Sa ma cyrecnr(twh St serie ngs vt emia ary wpa He umn ES SEES HEE sien Wh att ST Sn 
ee eS a a ae re eS LS CE ES SL A ES SE Te RN Th A SS 








(*) = Indicates Standard (non-Apple) FDD interface signal 
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2.3 Analog PLL Signals 








[Symbol _—_—«1/O_ Signal Function id 
LPF1, LPF2 Out LOW PASS FILTER. Phase difference of main PLL 
devices. 


CGP1,CGP2 Out CHARGE PUMP. Phase difference of sub PLL 





devices. 
2.4 Other Pins 
[Symbol VO Signal Fan bm aera 
DVDD - DIGITAL VDD. +5-volt power for digital circuits. 
DGND - DIGITAL GROUND, Ground for digital circuits. 
BGND - BUFFER GROUND, Ground for high current 
drivers. 
AVDD - | ANALOG Vpp. +5-volt supply for analog PLL. 
AGND - ANALOG GROUND. Ground for analog PLL. 


The following four pins are used for the Boundary Scan circuit: 


TCK I = Clock Input 

TDI I Data Input 

TMS I _— Used to select modes in this test circuit 
TDO O Data Output 





ee er re ere eee te eee mene ere ere wees 
aD Ce A OT 








D0-D7 INPUT 


DMARQ, INT In PC/AT™ Mode: HIGH IMPEDANCE 
In other modes : LOW 
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LPF1,LPF2, UNDEFINED 
CGP1,CGP2 


DS0-DS3, MEO, ME1, HIGH IMPEDANCE 
ENBLO/ME2, ENBL1/ME3, 

WDATA, WGATE, SEL/HDLD, 

CAO/DIR, CA1/STEP, 

CA2/SIDE, LSTRB 


DENO, DEN1 Depends on the data transfer rate. 


eer a ene Se rr ee a One eae eae er a SS ee ED ere es eu Sen are ae ne OC AA 
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2.6 Recommended Filter Parameters 


RS1 = 6.8K 


RS2 = 1.0K 

CS1 = 1,800pF 
CS2 = 22,000pF 
CM1 = 4,700pF 
CM2 = 68,000pF 





Note: The value on CM1 & CM2 sometimes will be required to adjust depending 
on user's machine. 
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2.7 Pin Connection Diagram 
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( ): For Standard Modes Only 
_B: Active Low Pins 





(WPRT_B) 
RDATA_B 
(DKCG_B/READY_B) 
AVDD 

LPF2 

LPF1 

AGND 

cape 

CGP1 

PCTYPE1 

PCTYPEO 

DRV2 


ENDKCG_B 
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Chapter 3 Internal Configuration 


3.1 Registers 


These following registers are available on the FDC. The Status Registers 
(STR) may contain one of five (5) different register contents. On the 
resultant phase of commands, it may contain the value for STO, ST1, ST2, or 
ST3. Please refer to the specific command for this information. 


REGISTERS 

1) Status resister (STR) 

2) Data register (DTR) 

3) Data Rate Register (DRR) 

4) PS/2 (TM) register set 
4-1) Status A register (SRA) 
4-2) Status B register (SRB) 
4-3) Digital output register (DOR) 
4-4) Digital Input register (DIR) 
4-5) Configuration Control register (CCR) 

5) Tape Drive Register (TDR) 


STATUS REGISTERS (Available only on the Result Phase ) 
6) Status 0 resister (STO) 
7) Status 1 resister (ST1) 
8) Status 2 resister (ST2) 
9) Status 3 register (ST3) 
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Under Apple mode, only 3 registers are available: the Status Register (STR), 
Data Register (DTR) and Data Rate Register (DRR). Table 3.1 shows how to 
select a register by setting address signals under an operation mode. 


Table 3.1 Register Selection under Operation Modes 
Mode __PCTYP1 PCTYPO CS A2 Ai AO R/W__ Register 


Apple 1 1 0 1 0 0 W _ Data Rate Register 


1 1 0 1 0 0 R _ Status Register 

1 1 0 1 O 1 W/R Data Register 
PS/2 0 0 0 0 0 0 R _ Status A Register 

0 0 00 0 1 + #=R  StatusB Register 

0 0 0 0 1 O R/W Digital Output Register 

0 0 0 0 1 #1 + #=W/R Tape Drive Register 

0 0 010 0 Ww Data Rate Register 

0 0 01 0 0 =#%&R Status Register 

0 0 0 1 0 1 + W/R _ Data Register 

0 0 01 1 #31 +W Config. Cntl. Register 

0 0 0171 1 +R Digital Input Register 
PC/AT 0 1 0 0 1 #O R/W Digital Output Register 

0 1 0 0 1 #1 + W/R_ Tape Drive Register 

0 1 01 00 Ww Data Rate Register 

0 1 01 0 0O R Status Register 

0 1 0 1 0 1 W/R __ Data Register 

0 1 01131 +$W Config. Cntl. Register 

0 0 01 1 1 R Digital Input Register 
General 1 0 01.00 WwW Data Rate Register 

1 0 0 1 O R Status Register 

1 0 0 1 0 1 + W/R Data Register 

X x 1X X X - No registers accessed 
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3.1.1 Status Resister (STR) 


Apple Mode 


[No] BitName | Symbot_| 
D7 | Request for Master |_ROM_| 
| D6 | DatainpuvOutput_| DIO _| 
|05 | Execution mode | EXM _| 
| pa|  FDCbusy | cB 
[bs |__Drivetinstaled | D1 _| 
|b2 | Driveoinstalled | Dor_| 
poi | FpDiBusy | diB | 
[bol FoDoBusy | bos _| 



















Standard Mode 


| No. | BitName | Symbol_| 
| 07 | Request for Master |_ROM _| 
| D6 | Data inpuvOutput_| _dIO_| 
[D5 | Execution mode | EXM _| 
| b4|  FDCbusy | cB 
jos|  FODsBusy | 3B __| 
| b2|  Fop2Busy | 2B | 
Pdi] Foi Busy | 1B 
| bo{ FDDOBusy | bop _| 















Fig. 3.1.1 Bit Function in the Status Register 


This register is a Read Only register. The function of this register is changed 
depending on the operation mode. 


UNDER APPLE MODE: 
RMOQ: This bit indicates the ready state to transfer data for host. Depending on 


the DIO bit state, ROM bit is set as follows: 
When DIO=0; 


The host sends data to FDC. When the host writes data into the 
FDC, ROM bit is reset to 0. When FDC receives this data, ROM 
bit is set to a high(1). 

When DIO=1; 
FDC sends data to the host. When FDC sets data in the Data 
Register, ROM bit is set to a high (1). When the host reads this 
data from the Data register, RQM bit is reset to 0. 


This bit indicates the direction of the data transferred between the host 
and the FDC. When this bit is reset as 0, data is transferred from the 
host to the FDC. When this bit is set as a high (1), data is transferred 


This bit indicates that data is being transferred by using the Non-DMA 
mode during the Execution phase. This bit is reset during the 


This bit indicates that the FDC is in the command phase, the execution 
phase if the read/write groups commands or the result phase. When 
this bit is set, no commands should be written to the Data Register. 


This bit indicates a second floppy disk drive is installed in the system. 


DIO: 
from the FDC to the host. 
EXM: 
command phase. 
CB: 
DI: 
DOI: 


This bit indicates the first floppy disk drive is installed in the system. 
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DIB: 


DIB: 


This bit indicates the the Seek Group commands are being performed 
on the second drive or a Seek Operation termination interrupt is 
pending. Read/Write commands must not be issued when this bit is 
active. 

This bit indicates the the Seek Group commands are being performed 


on the first drive or a Seek Operation termination interrupt is pending. 
Read/Write commands must not be issued when this bit is active. 


UNDER STANDARD MODES: 
RMQ: This bit indicates the Ready state to transfer data for host. Depending 


DIO: 


EXM: 


CB: 


D3B: 


D2B: 


DIB: 


DOB: 


on the DIO bit state, ROM bit is set as follows: 

When DIO=0; 
The host sends data to FDC. When the host writes data into the 
FDC, ROM bit is reset to 0. When FDC receives this data, ROM 
bit is set to a high(1). 

When DIO=1; 

The FDC sends data to the host. When FDC sets data in the 
Data Register, the ROM bit is set to a high (1). When the host 
reads this data from the Data Register, RQM bit is reset to 0. 


This bit indicates the direction of the data transferred between the host 
and the FDC. When this bit is reset as 0, data is transferred from the 
host to the FDC. When this bit is set as a high(1), data is transferred 
from the FDC to the host. 


This bit indicates that data is being transferred by using the Non-DMA 
mode during the Execution phase. This bit is reset during the 
command phase. 


This bit indicates that the FDC is in the command phase, the execution 
phase if the read/write groups commands or the result phase. When 
this bit is set, no commands should be written to the Data Register. 


This bit indicates the the Seek Group commands is being performed on 
the fourth drive or a Seek Operation termination interrupt is pending. 
Read/Write commands must not be issued when this bit is active. 


This bit indicates the the Seek Group commands is being performed on 
the third drive or a Seek Operation termination interrupt is pending. 
Read/Write commands must not be issued when this bit is active. 
This bit indicates the the Seek Group commands is being performed on 
the second drive or a Seek Operation termination interrupt is pending. 
Read/Write commands must not be issued when this bit is active. 


This bit indicates the the Seek Group commands is being performed on 
the first drive or a Seek Operation termination interrupt is pending. 
Read/Write commands must not be issued when this bit is active. 


32 


3.1.2 Data Register (DTR) 


This register consists of programmable length data FIFO with a maximum 
length of 16-bytes for data. Commands are also sent to this register but 
only one command byte is stored at one time. 


3.1.3 Data Rate Register (DRR) 


|.No.| __BitName __|_ Symbol _| 
|_D6 | enters standby mode|_STDBY_| 
| D5] reserved | = 
| D4 | 


Fig. 3.1.3.1 Bit function 





sets values for 


sets Data rate DRATE1 


This Write Only register is available under any operation mode. 
S/WRST: When this bits is set high (1), the FDC enters into the reset 


STDBY: 


PCS2-0: 


condition. This bit is automatically reset by itself. 


When this bit is set high (1), the FDC enters into the power down 
mode. In power down mode, all circuits are turned off. The FDC 
will terminate this mode after the reset condition, or when any 
register is read or written by the host. 


These bits select the preshift value of the write precompensator the 
FDC will use on the WDATA disk interface output. Table 3.1.8.1 
shows the values for these bits. 


In Apple Mode while recording in GCR, the precompensation 
value is always set to zero, independent of the bits (PCS2-PCS0) in 
the DRR register. 
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Table 3.1.8.1 PCS bits v.s. Preshift values 
2ED/2HD/2DD 2TD 


PCS2_ PCS1 PCSO _ Value(ns Value(ns 
a 0 - Reset default 
0 60 1 41.7 50.0 
0 1 0 83.3 100.0 
a 1 125.0 150.0 Apple's MFM value 
1 0 0 166.7 200.0 
1 0 1 208.3 Not used 
-1 1 0 250.0 Not used 
1 1 1 0.0 0.0 


Table 3.1.8.2 preshift values after reset condition 
2ED/2HD/2DD 2TD 
Data Rate(kbps value(ns)___ value(ns 


1000 41.7 - 
500 125.0 - 
300 125.0 - 
250 125.0 - 
1250 - 50.0 


DRATE1-0: These bits determine the data rate to be used. The data rates 
for MFM format are shown in Table 3.1.8.3. For FM format, 
the data rates become a half of the shown values in this figure. 
For data rates under Apple mode, these bits should be set as 
(DRATE1, DRATEO) = (0,0) or (DRATE1, DRATE0O)=(1,1). 


Table 3.1.8.3 DRATE bits v.s. Data Rates 
DRATE1] DRATEO __Data rate(kbps) 


0 0 500/489.6 

0 1 300 

1 0 250 (Reset default) 

1 1 1000/1250 (1000kbps is for 2ED media, 4MB) 


(1250kbs is for 2TD media; 13MB) 
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3.1.4 Status Register A (SRA) 


| No.| _BitName _|_ Symbol __ 
| Dé | _installeddrive2_| DRV2_B | 
| 05| _Stepsignal | STEP _| 
| 04 | _TrackOsignal_ | TRKO_B | 
| 03 | Sideselectsignal | SIDE _| 
| D2 {| __indexsignal__| INDEX_B | 
| D1 | Write protect signal 
| Do | _Directionsignal. | DR | 


Fig. 3.1.4 SRA Bit Function 











This Read Only register is available under Standard Modes only. 
Symbol Active Level ___ Description 


PINT High Reflects the state of the INT pin. 

DRV2_B Low Reflects if a second drive has been installed or not. 

STEP High Reflects the state of the STEP_B pin in the drive 
interface. 

TRKO_B Low Reflects the state of the TRKO_B pin in the drive 
interface. 

SIDE High Reflects the state of the SIDE pin in the drive 
interface. 

INDEX_B Low Reflects the state of the INDEX_B pin in the drive 
interface. 

WPRT_B Low Reflects the state of the WPRT_B pin in the drive 
interface. 

DIR High Reflects the state of the DIR pin in the drive 
interface. 
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3.15 Status Register B (SRB) 


[No.| _BitName __|_ Symbot_ 
|o7| reserved | ot 
| p6| reserved | 1 
| D5 | __DriveSelecto | Dso_| 
| D4 | Write Datasignal_| WDATA | 
| 03 | Read Datasignal_| RDATA_| 
22 {site aesnel | Ware 
| MotorOnt__ 


| Mot _| 
| bo] _Motorono__|_Moo_| 


Fig. 3.1.5 SRB Bit Function 


























This Read only Register is available under Standard Modes only. 


Symbol Active Level ___ Description 


DSO High Reflects the state of the DSO_B pin in the drive 
interface. 

WDATA High Reflects the state of the WDATA_B pin in the 
drive interface. 

RDATA High Reflects the state of the RDATA_B pin in the 
drive interface. 

WGATE High Reflects the state of the WGATE_B pin in the 
drive interface. 

MO1-0 High Reflects the state of the ME1-0_B pins in the drive 
interface. 
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3.16 Digital Output Register (DOR) 


| No.| _BitName _|_ Symbo!_| 
| 07 | Enables MoiorOn3 | EM3_| 
| D6 | Enables MotorOn2 | _EM2_| 
| D5 | Enables MotorOn1 | _EM1_| 
| D4 | Enables Motorono | EMO _| 
| D3 | Enables hostintertace| EHIF_| 
| b2| _EnablesFDC_ | RST_B | 


Peo | epeoe a 


Fig. 3.1.6 DOR Bit Function 

















This Write Only register is available under Standard Modes only. 


bol Active Level___ Description 
EM3-0 High Enable the Motor Enable Signals (ME3-0_B). 
EHIF High Enables the host interface signals INT, DMARQ, 
DMAAK _B and TC. 
RST_B Low Resets the FDC. Setting this bit to a "0" resets the 


controller. Setting this bit to a "1" enables the 
controller for operation. 


DS1-0: See Chart These bits select a floppy disk drive as the target to 
be read or written. The external Drive Select 
signals (DS3-0_B) become active according to the 
EM3-0 bits. 


bits in the Digital Output register 
EM3_EM2 EM1 EMO DS1 DSO | DS3_B DS2_B DS1_B DS0_B 
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3.1.7 Digital Input Register (DIR) 


| No.| __BitName _|_ Symbol _| 
|_Dé | reserved | - 
| D5| reserved =| —-_—i| 
| p4| reserved =| - 
|03| reserved | -_—i| 
| p2| _resewed | - _i| 
| pt | see oe 


reserved 


| bo] _reseved | 


Fig. 3.1.7 DIR Bit Function 













This Read only Register is available under Standard Modes only. 


1 Active Lev Description 
DSKCHG High Reflects the state of the external pin, 
DKCG/READY_B, when the external pin, 
ENDKCG B is set low. If this ENDKCG_B is set 
high, this register can not be accessed from the 
host. 
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3.1.8 Configuration Control Register (CCR) 


[No.|  BitName | Symbol_| 
| o7| reseed | = 
| b6| _resewed | = 
| os| resewed | = 

| 


reserved 





















reserved i 
reseved | - i 


selects data rate DRATE' 


Fig. 3.1.8.1 CCR Bit Function 


This Write Only register is available under Standard Modes only. 


Symbol Active Level ___ Description 


DRATE1-0 See Chart Determines the data rate to be transferred. 
The data rates for MFM format are shown in 
Figure 3.1.8.2. For FM format, these data rates 
become a half of the values shown. 


Fig. 3.1.8.2. DRATE bits v.s. Data Rates for MFM format 
DRATE1 DRATEO __Data rate(kbps) 


0 60 500 

0 1 300 

1 O 250 (reset default) 

1 1 1000/1250 (1000kbps is for 2ED media, 4MB) 


(1250kbs is for 2TD media, 13MB) 
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3.1.9 Tape Drive Register (TDR) 


| No.| _BitName | Symbol_ 
| p7| reserved | = 
| De| reserved | = 
|b5| reserved | 
| b4| reserved | = 
| b3| reseed | = 
| b2| reserved | = 









selects Tape drives 





Fig. 3.1.9 TDR Bit Function 


This Read and Write register is available under Standard Modes only. 


Symbol___Active Level___ Description | 

TDS1-0: These bits are not used in this FDC. These bits are 
necessary for this FDC to be compatible with the 
INTEL 82077. 
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3.1.9 Status Register 0 (STO) 


[wo | atime | sym 


pee | ao i 


oe ce 
ios (eee 
Bed eee oad 
(eimai co 











bol Active Level _ Description 


D7-D6 ~~ See Chart Indicates the causes of the INT request 
D7_ D6 Indicated causes 
0 0 Normal termination of command execution 
a | Abnormal termination of command execution 
1 O Invalid command issued 
1 #1 Under Apple Mode: 


/CSTIN state change, floppy media inserted or removed 
Under standard modes: 
Indicates a changed status of FDD 


D5 High This bit is set when a seek operation by Seek or 
Recalibrate command is terminated normally or 
abnormally 

D4 High Under Apple mode, this bit is set when errors at 


the FDD occur. Under Standard modes, this bit is 
set when the TRKO signal can not be detected 
within a certain period in execution if the 
Recalibrate command. 
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D3 


D1 


3.1.10 Status Register 1 (ST1) 


High 


High 


High 


High 


Under Apple mode, this bit reflects the /Ready 
status in the drive interface. Under standard 
modes, this bit reflects the READY_B pin. 

This bit indicates the head status at the time of the 
INT request. This bit is set to zero when Sense 
Interrupt Status command is executed. 


Under Apple mode, this bit reflects the /CSTIN 
status in the drive interface. Under standard 
modes, this bit indicates the drive number (DRI), 
as same as the drive select bit (DR1) in the 
command, at the time of the INT request. 


Under all modes, this indicates the drive number 
(DRO), as same as the drive select bit (DRO) in the 
command, at the time of the INT request. 


No. Bit Name Symbol Function 


D7 ‘End of Cylinder 


D5 


D3 
D2 


Data Error 


Overrun 


No Data 


EN This bit is set when read or 
write is attempted beyond the last 
sector specified by the EOT byte. (TC 


signal is NOT INPUT) 
7 This bit is always set to zero. 
DE Under Apple mode, this bit is set 


when the checksum error at the ID 
field or Data field is detected. DD bit 
(D5) of Status Register (ST2) specifies 
either ID or Data field. 


OR This bit is set when data transfer 
service by the host is not performed 
within the specified amount of time 
at the data transfer. 


- This bit is always set to zero. 


ND 1) This bit is set if the sector specified 
by the IDR can not be detected on the 
track when any one of the following 
five commands is executed: 
- Read Data - Read Deleted Data 
- Write Data - Write Deleted Data 
- Scan group commands 

2) This bit is set when an ID with no 
CRC error or no checksum error is 
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Di 


Not Writable 


NW 


DO Missing Address Mark MA 


3.1.11 Status 2 Register (ST2) 


not detected on the track in the 
execution of Read ID command. 


3) This bit is set when the sector ID 
and the contents of the specified IDR 
does not matched at the Read a Track 
command execution. 


This bit is set when the write protect 
signal is detected by execution of a 
write group commands. 


I)This bit is set when the IDAM can 
not be found before two index pulses 
(or the allowable period ) are detected 
by the execution of a command that 
accesses the ID of the disk. 

2)This bit is set when the DAM or 
DDAM can not be found after the 
IDAM is found. MD bit of Status 
register (ST2) is also set at this time. 


No. Bit Name Symbol Function 


D7 
D6 


D5 


D4 


D3 


D2 


Control Mark 


CM 


Data Error in Data field DD 


No Cylinder 


Scan Equal Hit 


Scan Not Satisfied 


NC 


SH 


SN 


This bit is always set to zero. 


This bit is set when the DDAM is 
detected at the Read Data, Read a 
Track or Scan group commands 
execution or when the DAM is 
detected at the Read Deleted Data 
execution under MFM format. 


This bit is set when the checksum 
error at the Data field is detected. 


When either C byte of ID matches 
nor $FF, this bit is set together with 
ND bit of Status register 1 (ST1). 

This bit indicates the Equal condition 


to be occurred at the scan group 
commands. 


This bit is set when the condition is 
not satisfied at the scan group 
commands. 


D1 Bad Cylinder BC This bit is set together with the ND 
bit of Status register 1 (ST1) when the 
C byte of ID field is $FF. 

DO Missing DAM MD This bit is set when the Data Address 
Mark (DAM) or DDAM can not be 
found after the IDAM is found. 

3.1.12 Status Register 3 (ST3) 
Apple Mode 

No. Bit Name Symbo] Function 

D7 2MB/4 MB Media Media This bit reflects the /2MB or /4MB 
media status from the drive. 

Dé Write Protect WP This bit reflects the /Write protect 
status from the drive. 

D5 Ready RY This bit reflects the /Ready status 
from the drive. 

p4 Track 0 TO This bit reflects the TrackO status 
from the drive. 

D3 2MB-4MB drive Drive This bit reflects the 2MB-4MB drive 
status from the drive. 

D2 Mode ID Mode This bit reflects the Mode ID status 
from the drive. 

D1 Select media SelMedia This bit reflects the Select Media 
status from the drive. 

DO MFM mode MFM This bit reflects the MFM Mode 
status from the drive. 

Standard Modes 

No. Bit Name Symbol Function 

D7 Fault FT This bit is always set to zero. 

D6 Write protect WP This bit reflects the WPRT_B pin in 
the drive interface. 

DS Ready RY This bit reflects the READY_B pin in 
the drive interface. 

D4 Track 0 TO This bit reflects the TRKO_B pin in 
the drive interface. 

D3 Two Side TS This bit is always set to high (1). 

D2 Head Address HD This bit reflects the SIDE_B pin in t 
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he drive interface. 


D1 Drive Select 1 DRI This bit reflects the DRI bit in the 
issued command. 
DO Drive select 0 DRO This bit reflects the DRO bit in the 


issued command. 


3.2 System Interface Control 


The block diagram shown in Figure 3.2.1 shows the functional blocks that 
handle the transfer of data between the host and this FDC. 


Fig. 3.2.1 72077 System Block Diagram 










TCK— p> 
wa xa am (DS0) 
TDO—p , Clock DS1 
XB Generator = 
Vata Rate MEO) 
Register MESS 
ENBLO(IME2 
ay le ane 
Control 
>Gi NAY] Registers Drive CAO TEP) 
Interface CA2 (SIDE) 
LSTRB 
Drive wate 
Interface ) 41 
Control Tro) 
DKCG/READ 
Systemco ENDKCG) 
(DRV2) 
DB7-0 
WDATA 
WGATE 
RDATA 
LPF1 
LPF2 
CGP1 
CG 


( ): For standard FDD 
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3.3 Serial Interface Control 
This block is used to change data from bytes to serial bits and from serial 
bits to bytes for the read/write groups commands. 

3.4 Drive Interface Control 
This block is used to handle the output signals to FDDs and the input 
signals from FDDs. 

3.5 Drive Interface 
This block consists of the high current drivers and the receivers for FDD 
signals. 

3.6 Analog PLL 
This block generates the Read-clock to be synchronized with the RDATA 
signal from FDD. 

3.7 System Clock Generator 
This block generates the internal clocks required for the internal blocks 
from XA and XB clock source. 


3.8 Precompensator Control 


This block generates the WDATA signal to be preshifted according to the 
programmed value. Under GCR mode, this block is always disabled. 
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Chapter 4 Commands 


The following is an explanation of Common Parameters in commands used 
in the FDC: 


FM (Recording Mode Format) 


Under Apple mode, the FDC can operate in MFM recording mode when 
this bit is set 1(high) and the FDC can operate in GCR recording mode 
when this is set 0@ow). 


Under Standard modes, the FDC can operate in MFM recording mode 
when this is set 1(high) and the FDC can operate in FM recording mode 
when this is set 0(low). 


MT (Multi Track) 
When this bit is 1(high), the operation to Read or Write for multi tracks 
is specified. 

TB (Tag Byte for GCR recording) 
During operations that write data to the FDD, when this is 1(high), the 
data for the Tag byte field must be transferred from the host to the FDC. 


During operations that write data to the FDD, when this is O(low), the 
Tag byte field is automatically filled with "0". This does not require any 
transfer from the host. 


During operations that read data from the FDD, when this is 1(high), the 
Tag byte field is transferred from the FDC to the host. 


During operations that read data from the FDD, when this is O(low), the 
Tag byte field is not transferred. 

SK (SKIP under standard modes) 
When this bit is I(high) and FDC detects the DDAM during operating the 
Read Data command or when this is 1(high) and FDC detects the DAM 
during operating the Read Deleted Data command, the data in the data 
field to be transferred are skipped. 


When this bit is O0dow), the data in the data field are transferred. 
HD (Head) 
Specifies the physical head number. When this bit is 1(high), side 1 is 
selected and when this is 0(low), side 0 is selected. 
DR1,0 (Drive Select) 
Specifies the drive number from 0 to 3. 
CYLINDER 
Indicates the cylinder number 
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Gap4 is located from the last position of the last sector from the index 
position. 
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.Configure 



















D7 D6 D5 D4 "3 = 2 = 
1 


0 0 0 command code 
0 0 0 0 : ; ; 5 


0 EIS EFO PoL| FIFOTHR 


Sets parameters as 
specified. 


FUNCTION 
The host uses this command to set several internal parameters in the FDC. 






PARAMETERS 

EIS Under only Standard modes, the EIS enables the FDC to 
perform the Seek command before the FDC performs the 
Read/Write groups commands without issued Seek 
command. When EIS is set a high(1), this implied seek 
function becomes active. 

EFO The EFO bit is used to enable the Data FIFO in the FDC. When 
this EFO is set a low (0), the Data FIFO is enabled. When this 
EFO is high (1), the Data FIFO is disabled. 

POL The POL bits is irrelevant to the FDC operation. 

FIFOTHR Once the EFO bit is set a high(1), the FIFOTHR bits is used to 
determine the threshold of the Data FIFO during the FDC is 
operating the Read/Write groups commands in the Execution 
phase. This threshold can be programmed from 1 to 16 bytes. 

PRETRK The PRETRK bits are used to specify the track to begin 
precompensation of the FDD write data . 


ERROR CONDITIONS 
There are no error condition for this command. 


Disable/Enable DPLL 
|_Phase | RW|D7 Dé D5 D4D3 D2 D1 D0 | _ Remarks 
eget d sa 

wi|xX xXx X X X X X DR 
== 
value 


FUNCTION 

Under Apple mode only, the effect of this command is to set the /DPLL 
command bit in the FDD. This disables the integrated Digital Phase Lock 
Loop (DPLL) in the FDD. The FDC will not handshake this command. 






DL="0" DPLL DISABLED 
DL="1" DPLL ENABLED 


ERROR CONDITIONS 


This command has no error condition because this command is used only 
in a development environment. 
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Dumpreg 


PCNO Dumps internal used 
PCN1 parameters. 
PCN2 
PCN3 
Step Rate i Head Unload time 
Head Load time i ND 


Number of Sectors per Track 
(or End of Track) 
reserved 


0 EISEFOPOJ = FIFOTHR 
PRETRK 
























UZDVDVDVIIIIIAIIVIV 






FUNCTION 


The host can get the internal parameters to be used in the FDC by using 
this command. This command can be used under Standard modes. 


ERROR CONDITIONS 
This command has no error conditions. 
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Eject Disk 
| Phase | Rw| D7 De DS D D3_D2 Di DO 
eects 

X X X X X X X DR 
Floppy disk is ejected 
from FDD by asserting 
/EJECT contro! signal 


FUNCTION 

Under Apple mode only, this command is used to programmatically eject 
the floppy in the selected drive. This is done by writing the /Eject control 
bit in the specified drive. Immediately after asserting the /Eject command 
to the FDD, the FDC will issue a normal termination interrupt. 









a 







ERROR CONDITIONS 


Due to the extremely long time, it takes to execute an Eject command, 
there is no handshaking done by the FDC. In normal operation, the host 
will be notified of the completion of the Eject command via an interrupt 
indicating the change in the /CSTIN status line. This can be used to verify 
that the media has been properly ejected. 


Format A Track 


Phase | aw D7 Dé DS D4 03 D2 D1 Do 


Command 0 FM TB O command code 
Xx X X X : cals 


(Bytes/Sector) / Format Byte 







Sectors/Track 
GAP3(MFM) / #Sync Groups(GCR 
Filler Byte 


Execution FDC formats the entire 
track 


Status Regisiter 0 status information 
Status Regisiter 1 after this command 
Status Regisiter 2 
Cylinder(irrelevant) 
Head(irrelevant) 
Sector(irrelevant) 





Z=fzzt2e 
















FUNCTION 

This command allows an entire track to be formatted. The host must send 
new values for the cylinder, head, sector and the number of data bytes, to 
the FDC for each sector to be formatted during the execution phase of this 
command. If the FDC is in DMA transfer mode, it will issue four DMA 
requests per sector for the cylinder, head, sector and the number of data 
bytes for each formatted sector. 

If the FDC is in non-DMA transfer mode, it will issue four interrupts per 
sector and the host must supply the cylinder, head, sector and the number 
of data bytes for each formatted sector. 

For MFM or FM recording, data is written on the disk after the index hole 
is detected. But for GCR recording, the write can begin anywhere on the 
track. The host specifies the format of the track by the parameters passed 
during the command phase. Tag bytes transfer is controlled by the TB 
parameter. 


PARAMETERS 


BYTES/SECTOR __ This is used as the number of bytes in a sector. For 
GCR recording, this byte should be either 12H, 22H 
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or 24H. All these hexidecimal values (12H, 22H or 
24H ) represent 512 bytes of data and 12 Tag bytes. 
For MFM recording, see the following; 


Bytes in a sector 
Bytes /Sector(16 MFM FM 
00 inhibited 128 

01 256 256 

02 512 512 

03 1024 1024 

04 2048 2048 

05 4096 4096 

06 8192 8192 


Note *1: GAP3 in this case should be set less than 128bytes. 


SECTORS/TRACK This is used as the number of sectors in a 

track. 

# SYNC GROUPS(GCR) / GAP3(MFM) 
For GCR recording, this specifies the number 
of the Self Sync byte group. And for MFM 
recording, this specifies the number of the 
bytes in the GAP3. 

FILLER BYTE This byte is written into the data field as the 
data pattern. 


— 


ERROR CONDITIONS 
Errors occur under the following conditions: 
- The WPRT status becomes active. 
- The overrun or underrun occur during the data transfer. 
- When utilizing the TC input, it does not meet the correct 
timing period. 
Under Apple mode: 
- The /CSTIN status in the drive interface is inactive before this 
is operated. 
Under any mode: 


- The Ready status at the drive interface is inactive before this is 
operated. 
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Format/Write 


O FM T0000 1 

X X X X X HD DR1DRO 

(Bytes/Sector) / Format Byte 
Sectors/Track 


track data is passed to 
FDC as in a write 
Operation 


Status Regisiter 0 status information 
Status Regisiter 1 after this command 
Status Regisiter 2 
Cylinder(irrelevant) 

Head(irrelevant) 

Sector(irrelevant) 


FUNCTION 

This command is virtually the same as the Format a Track command with 
the exception that the filler byte in not specified. Instead, the host transfers 
the data as in the Write Data command. This capability is required to 
optimize when writing data and to support GCR recording on 
perpendicular FDD drives. 

This command allows an entire track to be formatted. 


The host must send new values for the cylinder, head, sector and the 
number of data bytes, to the FDC for each sector to be formatted. 


PARAMETERS 
These parameters are same as that of the Format a Track command. 


ERROR CONDITIONS 
Errors occur under the following conditions: 
- The WRITE PROTECT status is active. 
- The overrun or underrun occur during the data transfer. 


- Under Standard / Apple modes, the drive interface indicates a 
NON_READY drive status. 
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Invalid 
In the following two cases, 10(2) (IC: Invalid Command) is set to the 
Interrupt code (high bits) of STO, and is set to all remaining bits (STO=80H). 
¢ When an undefined command code is issued 


* When the Sense Interrupt Status command is activated even though 
an INT request by termination of the seek group commands or by a 
drive status change is not generated. 
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Perpendicular Mode 


|_ae_| rw o7 06 0s 04 09 2 D100 


Twloj oo 0 0 


ae Xx X x Xx X X D1 Do | Echo back for this 
command. 


FUNCTION 


The Perpendicular Mode command should be issued prior to executing 
READ / WRITE / FORMAT commands that access a disk drive with 
perpendicular recording capability. With this command, the length of the 
GAP2 field and VCO enable timing can be altered to accommodate the 
unique requirements of these disk drives. Please refer to the following 
table for the perferred settings. Selection of the 500 Kbps and 1 Mbps 
perpendicular modes is independent of the actual data rate selected in the 
Data Rate register. The User must ensure that the two data rates remain 
consistent. 


VCO Low | Lengthof | Portion of Gap2 | Gap2 VCO 
= —e Written by Write Low tme/ 
So 


[= [Pr fe mo 


1Mbps 


Effects of Perpendicular Mode in GCR and MFM Formats 


Write Gate | Write Gate / 















i Write Data 
Wine Bete Valid Write Data 
TI T1 
Read Data 
Valid Read Data 
T1 VALUES Ti VALUES 
—~GCR_ IMB IMEEM) 2MB (MEM) 4MiD (MEM) 
154usec 304usec 304 usec 304 usec 190 usec 190 usec 340 usec 340 usec 
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Raw Dump 


| Phase | RW| D7 D6 DS D4 D3 D2 Di 09 


O FM 0 1 1-—= 1 command code 
x x x | Rom [xo ee 
Cylinder 
Head 
Sector 
Sector Number 
Bytes to dump(MSB) 


























# of bytes is a 16-bit 
unsigned long integer 


Data is passed back to 
Host. GCR is returned 
encoded. 


Status Regisiter 0 status information 
Status Regisiter 1 after this command 


Status Regisiter 2 
Cylinder(irrelevant) 
Head(irrelevant) 
Sector(irrelevant) 
Number of data eyes 


















Dvuymyvva yv 


FUNCTION 


Under Apple mode only, this command supports the following three 
dump modes: 

- Dump from the Index Address Mark 

- Dump after the specified ID Address Mark 

- Dump after the Data Address Mark 


In addition, the FDC begins to transfer data after the FDC is synchronized 
to the nearest available mark in incoming Data from FDD. After the 
FDC starts to transfer data, it may be possible for the FDC to lose 
synchronization with the incoming data because of write splices. If this 
occurs, meaningless data will be transfered to the host. 

The detected mark byte, which the FDC starts to dump data from, is 
defined under the MFM format that this mark byte is located after the 
SYNC bytes and the Data and Clock bytes of this mark byte is equal to 
either $A1 for Data byte and $0A for Clock byte or $C2 for Data byte and $14 
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for Clock byte. 

On the other hand, the detected mark byte is also defined under the GCR 
format that this mark byte is located after the SYNC bytes and the Data byte 
of this mark byte is equal to $D5, which is the first data of either Address 
mark bytes or Data Address mark bytes. 

Regarding transfered data under the ONLY MFM FORMAT, the FDC 
transfers one Data byte and one Clock byte from FDD to the host 
repeatedly. The host should check what Clock byte has missing clock bits 
by itself. This transfer is called as the 8 X 8 data transfer and is described 
later for further detailed. Under the GCR format, the raw data from the 
FDD should be transfered to the host without denibbling. 


1) DUMP FROM INDEX ADDRESS MARK 

Under MFM format only, this dumps the requested number of bytes 
from the track specified, immediately after the Index pulse is input to the 
FDC and the SYNC bytes are detected and then the Index Address mark, 
which consists of both the data byte with $C2 and the Clock byte with $14, 
is detected. The data that is transfered to the host will include the Index 
address mark itself and the track data according to the rule of the 8 X 8 
data transfer. 
But under the GCR format, this mode is illegal because the FDD can not 
output the Index pulse from itself. 
When the RDM bits are set to "00", this mode can be entered. 
In this mode, the FDC ignores the following errors after the first Address 
mark is found. 

- Read error for CRC for the MFM format 

- Read error for Address Mark in the Data field 


INDEX 
Pulse 
a _ 1... [D fied ————— > 
Syne INDEX Syne Address address 
GAP byte markbyte GAP byte mark header GAP2 


transfered data from this point from 
Fig. 4.18.1 Transferred Data for Dump From Index Address Mark 
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2) DUMP AFTER SPECIFIED ID ADDRESS MARK 


When the RDM bits are set to "01", this mode can be entered under the 
only Apple mode. 


This dumps the requested number of bytes from the specified track. 
Especially under the MFM format, after the FDC finds out the specified 
ID address mark and then the nearest SYNC bytes, the FDC checks 
whether the next data after these SYNC bytes is equal to the Mark byte, 
which is expected as the $A1 for Data byte and the $0A for Clock byte. If 
this mark is hit, the FDC should start to dump data from and including 
this Mark byte. But if the Mark byte can not be hit, the FDC changes the 
expected Data for the Mark byte from the above data to the $C2 for Data 
byte and the $14 for Clock byte and then the FDC resumes to search the 
same specified ID field. 

After the FDC finds out the specified ID address mark and then the 
nearest SYNC bytes, the FDC checks whether the next data after these 
SYNC bytes is equal to the Mark byte, which is expected as the $C2 for 
Data byte and the $14 for Clock byte. If this mark is hit, the FDC should 
start to dump data from and including this Mark byte. But if the mark 
byte can not be hit, the FDC abnormally terminates the command and 
interrupts to inform to the host this abnormal termination. 

For GCR format, after the FDC finds out the specified ID address mark, 
the FDC is waiting to receive the Mark byte with the $D5 for Data byte. If 
this mark is hit, the FDC should immediately start to dump data from 
and including this Mark byte. But if the mark byte can not be hit, the 
FDC abnormally terminates the command and interrupts to inform to 
the host this abnormal termination. In addition, the FDC dumps the 
data without denibblizing the read-data from the FDD. 


The Fig. 4. 18. 2 is shown as a example of this mode. In this example, the 
Data Address mark is located after the specified ID field and the SYNC 
bytes. 


In this dumped mode, the FDC ignores the following errors after the first 
Address header is found out 


- Read error for CRC for the MFM format or Checksum for 
the GCR format 


- Read error for Bit slip byte for the GCR format 
- Read error for Address mark in the Data field 
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Register Name & Bit Symbol Reference 


Symbol 


FIN 


IC(1) 
1e(2) 
MA 
MD 
Media 
MFM 
Mode 
NC 

ND 

NR 
NW 
OR 
PCSO 
PCS1 
PCS2 
RQM 
RY 
S/W RST 
SE 
SelMedia 
SH 

SN 
STDBY 
TO 

WP 


Name 


Reserved 

Reserved 
Reserved 
Reserved 

Bad Cylinder 

FDC Busy 

Control Mark 

Drive 0 Busy 

Drive 0 Installed 
Drive 1 Busy 

Drive 1 Installed 
Data Error in Data Field 
Data Error 

Data Input/Output 
Drive 

Data Rate(0) 

Data Rate(1) 
2MB/4MB Drive 
Equipment Check 
End of Cylinder 
Execution Mode 
Floppy In 

Head Address 
Interrupt Code(1) 
Interrupt Code(0) 
Missing Address Mark 
Missing Data Mark 
2MB/4MB Media 
MFM Mode 

Mode ID 

No Cylinder 

No Data 

Not Ready 

Not Writable 
Overrun 
Precompensation(0) 
Precompensation(1) 
Precompensation(2) 
Request for Master 
Ready 

FDC Software Reset 
Seek End 
Select Media 
Scan Equal Hit 

Sean not Satisfied 
Standby Mode 
Track 0 
Write Protect 


Location 
DRR(5) 


_$T1(6) 


ST1(6) 
ST2(7) 
$T2(1) 

STR(4) 
ST2(6) 
STR(O) 
STR(2) 

STR(1) 
STR(3) 
$T2(5) 
ST1(5) 
STR(6) 
STO(0) 
DRR(O) 
DRR(1) 
$T3(3) 
STO(4) 
ST1(7) 
STR(5S) 
ST0(1) 
ST0(2) 
ST0(7) 
STO(6) 
$T1(0) 

ST2(0) 
$T3(7) 
ST3(0) 
$T3(2) 
ST2(4) 
$T1(2) 
STO(3) 

ST1(1) 
ST1(4) 
DRR(2) 
DRR(3) 
DRR(4) 

STR(7) 
ST3(5) 
DRR(7) 
STO(5) 
$T3(1) 
$T2(3) 
ST2(2) 
DRR(6) 
ST3(4) 
ST3(6) 
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8.4.1.2 State Description. 


The Behavior of the TAP controller in each of the controller states is briefly 
described as follows: 


Test-Logic-Reset 

The JTAG implemented into the FDC is disabled so that normal operation of 
the FDC system logic can continue unhindered. This is achieved by 
initializing the instruction register to contain the BYPASS instruction. No 
matter what the original state of the TAP controller, it will enter Test-Logic- 
Reset when TMS is held high for at least five rising edges of TCK. The TAP 
controller remains in this state while TMS is high. 


If the TAP controller should leave the Test-Logic-Reset TAP controller state as 
a result of an erroneous low signal on the TMS line at the time of a rising 
edge on TCK (for example, a glitch due to external interference), it will return 
to the Test-Logic-Reset state following three rising edges of TCK with the TMS 
line at the intended high logic level. The operation of the test logic is such 
that no disturbance is caused to the FDC logic operation as the result of such 
an error. On leaving the Test-Logic-Reset controller state, the TAP controller 
moves into the Run-Test/Idle controller state where no action will occur 
because the current instruction has been set to select operation of the bypass 
register. This JTAG logic is also inactive in the Select-DR-Scan and Select-IR- 
Scan controller states. 


Run-Test/Idle 


This is a TAP controller state between scan operations. Once entered, the TAP 
controller will remain in the Run-Test/Idle state as long as TMS is held low. 
When TMS is high and a rising edge is applied at TCK, the TAP controller 
moves to the Select-DR-Scan state. 


In the Run-Test/Idle controller state, activity in a certain selected instruction 
occurs only when certain instructions are present. 


For instructions that do not cause functions to execute in the Run-Test/Idle 
controller state, all test data registers selected by the current instruction retains 
their previous state (i.e., Idle). 


The instruction does not change while the TAP controller is in this state. 


Select-DR-Scan 


This is a temporary controller state in which Boundary -Scan and Bypass 
registers selected. by the current instruction retain their previous state. 


If TMS is held low and a rising edge is applied to TCK when the TAP 
controller is in this state, then the TAP controller moves into the Capture-DR 
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state and a scan sequence for the selected register is initiated. If TMS is held 
high and a rising edge is applied to TCK, the TAP controller moves on to the 
Select-IR-Scan state. 


The instruction does not change while the TAP controller is in this state. 


Select-IR-Scan 


This is a temporary controller state in which Boundary-Scan and Bypass 
registers selected by the current instruction retain their previous state. 


If TMS is held low and a rising edge is applied to TCK when the TAP 
controller is in this state, then the TAP controller moves into the Capture-IR 
state and a scan sequence for the Instruction register is initiated. If TMS is 
held high and a rising edge is applied to TCK, the TAP controller returns to 
the Test-Logic-Reset state. 


The instruction does not change while the TAP controller is in this state. 


Capture-DR 

In this controller state, data are parallel-loaded into Boundary-Scan registers 
selected by the current instruction on the rising edge of TCK. 

The instruction does not change while the TAP controller is in this state. 


When the TAP controller is in this state and a rising edge is applied to TCK, 
the TAP controller enters either the Exit1-DR state if TMS is held at 1 or the 
Sift-DR state if TMS is held at 0. 


Shift-DR 


In this controller state, either Boundary-Scan or Bypass register connected 
between TDI and TDO as a result of the current instruction shifts data one 
stage towards its serial output on each rising edge of TCK. 


Boundary-Scan and Bypass register that are selected by the current instruction, 
but are not placed in the serial path, retains their previous state unchanged. 


The instruction does not change while the TAP controller is in this state. 


When the TAP controller is in this state and a rising edge is applied to TCK, 
the TAP controller enters either the Exit1-DR state if TMS is held at 1 or 
remains in the Shift-DR state if TMS is held at 0. 


Exiti-DR 


This is a temporary controller state. If TMS is held high, a rising edge applied 
to TCK while in this state causes the TAP controller to enter the Update-DR 
state, which terminates the scanning process. If TMS is held low and a rising 
edge si applied to TCK, the TAP controller enters the Pause-DR state. 
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Boundary-Scan and Bypass registers selected by the current instruction retain 
their previous state unchanged. 


The instruction does not change while the TAP controller is in this state. 


Pause-DR 


This controller state allows shifting of either Bypass or Boundary-Scan 
register in the serial path between TDI and TDO to be temporarily halted. 
These registers selected by the current instruction retain their previous state 
unchanged. 

The TAP controller remains in this state while TMS is low. When TMS goes 
high and a rising edge is applied to TCK, the TAP controller moves on to the 
Exit2-DR state. 


The instruction does not change while the TAP controller is in this state. 


Exit2-DR 

This is a temporary controller state. If TMS is held high and a rising edge is 
applied to TCK while in this state, the scanning process terminates and the 
TAP controller enters the Update-DR controller state. IF TMS is held low and 
a rising edge is applied to TCK, the TAP controller enters the Shift-DR state. 


Bypass and Boundary-Scan registers selected by the current instruction retain 
their previous state unchanged. 


The instruction does not change while the TAP controller is in this state. 


Update-DR 

Boundary-Scan register is provided with a latched parallel output to prevent 
changes at the parallel output while data is shifted in the associated shift- 
register path in response to certain instructions (e.g., EXTEST). Data is latched 
onto the parallel output of this register from the shift-register path on the 
falling edge of TCK in the Update-DR controller state. The data held at the 


‘latched parallel output should not change other than in this controller state. 


All shift-register stages in Boundary-Scan register selected by the current 
instruction retain their previous state unchanged. 


The instruction does not change while the TAP controller is in this state. 


When the TAP controller is in this state and a rising edge is applied to TCK, 
the TAP controller enters either the Select-DR-Scan state if TMS is held at 1 or 
the Run-Test/Idle state if TMS is held at 0. 


Capture-IR 
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In this controller state, the shift-register contained in the instruction register 
loads the pattern (01 binary) of fixed logic values on the rising edge of TCK. 


Either Bypass or Boundary-Scan register selected by the current instruction 
retain their previous state. The instruction does not change while the TAP 
controller is in this state. 


When the TAP controller is in this state and a rising edge si applied to TCK, 
the TAP controller enters either the Exit1-IR state if TMS is held at 1 or the 
Shift-IR state if TMS is held at 0. 


Shift-IR 


In this controller state, the shift-register contained in the instruction register 
is connected between TDI and TDO and shifts data one stage towards its serial 
output on each rising edge of TCK. 


Either Bypass or Boundary-Scan register selected by the current instruction 
retain their previous state. The instruction does not change while the TAP 
controller is in this state. 


When the TAP controller is in this state and a rising edge is applied to TCK, 
the TAP controller enters either the Exit1-IR state if TMS is held at 1 or 
remains in the Shift-IR state if TMS is held at 0. 


Exit]-IR 
This is a temporary controller state. If TMS is held high, a rising edge applied 
to TCK while in this state causes the TAP controller to enter the Update-IR 


state, which terminates the scanning process. If TMS is held low and a rising 
edge is applied to TCK, the TAP controller enters the Pause-IR state. 


Either Bypass or Boundary-Scan register selected by the current instruction 
retain their previous state. The instruction does not change while the TAP 
controller is in this state and the instruction register retains its state. 


Pause-IR 


This TAP controller state allows shifting of the instruction register to be 
halted temporarily. 


Either Bypass or Boundary-Scan register selected by the current instruction 
retain their previous state. The instruction does not change while the TAP 
controller is in this state and the instruction register retains its state. 


The TAP controller remains in this state while TMS is low. When TMS goes 
high and a rising edge is applied to TCK, the TAP controller moves on to the 
Exit2-IR state. 


Exit2-IR 
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This is a temporary controller state. If TMS is held high and a rising edge is 
applied to TCK while in this state, termination of the scanning process 
results, and the TAP controller enters the Update-IR controller state. If TMS is 
held low and a rising edge is applied to TCK, the TAP controller enters the 
Shift-IR state. 


Either Bypass or Boundary-Scan register selected by the current instruction 
retain their previous state. The instruction does not change while the TAP 
controller is in this state and the instruction register retains its state. 


Update-IR 

The instruction shifted into the instruction register is latched onto the 
parallel output from the shift-register path on the falling edge of TCK in this 
controller state. Once the new instruction has been latched, is becomes the 
current instruction. 

Either Bypass or Boundary-Scan register selected by the current instruction 
retain their previous state. 

When the TAP controller is in this state and a rising edge is applied to TCK, 
the TAP controller enters the Select-DR-Scan state if TMS is held at 1 or the 
Run-Test/Idle state if TMS is held at 0. 


The Pause-DR and Pause-IR controller states are included so that shifting of 
data through Bypass, Boundary-Scan or instruction register can be 
temporarily halted. 
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8.4.1.3 TAP Controller Operation 
The operation of this TAP controller is as follows: 


The TAP controller shall only change state in response to the following 
events: (i) A rising edge of TCK or (ii) Power-up. 
The TAP controller generates signals to control the operation of Bypass, 


Boundary-Scan and instruction registers as defined in this standard (Figs 8.4-3 
and 8.4-4). 


The TDO output buffer and the circuitry that selects the register output fed to 
TDO are controlled as shown in Table 8.4-1. 


Changes at TDO defined in Table 8.4-1 occur on the falling edge of TCK 
following entry into the state. 


Table 8.4-1 Operation in Each Controller State 
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Controller State Register Selected to Drive TDO TDO Driver 
Test-Logic-Reset Undefined Inactive 
Run-Test/Idle Undefined Inactive 
Select-DR-Scan Undefined Inactive 
Select-IR-Scan Undefined Inactive 
Capture-IR Undefined Inactive 
Shift-IR Instruction Active 
Exit1-IR Undefined Inactive 
Pause-IR Undefined Inactive 
Exit2-IR Undefined Inactive 
Update-IR Undefined Inactive 
Capture-DR Undefined Inactive 
Shift-DR Test data Active 
Exit1-DR Undefined Inactive 
Pause-DR Undefined Inactive 
Exit2-DR Undefined Inactive 
Update-DR Undefined Inactive 
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The assignment of controller states in the example implementation is 


given in Table 8.4.-2 (see the section 8.4.3) . 
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TCK 


TMS 
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Parallel output of TDR Old data New data 
Register selected Test data register 
TDO enable_ Inactive Inactive 
TDO 





= Don't care or undefined 
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8.4.1.4 TAP Controller Initialization 
The initialization for this TAP controller is as follows: 


(a) The TAP controller is forced into the Test-Logic-Reset controller 
state at power-up by the power-on-reset circuitry built into the FDC. 


(b) The TAP controller is not initialized by operation of any system 
input, such as a system reset. 

(c) The TAP controller can synchronously enter into the Test-Logic- 
Reset controller state following five rising edges at TCK (provided TMS 
is held high). 


8.4.2 Instruction Register 

As this register is described at the section 8.2, this register is specified by the 
following; : 

1) The Instruction shifted into the instruction register is latched such that 
changes in the effect of an instruction occur only in the Update-IR and the 
Test-Logic-Reset controller states 

2) There is no inversion of data between the serial input and the serial output 
of the instruction register. 

3) This register cell loads a fixed binary "01" pattern data, the 1 into the least 
significant bit location, in the Capture -IR controller state. 

4) This register is set to a fixed binary "01" pattern data, the 1 into the least 
significant bit location, during the Test-Logic-Reset controller state. 

5) When this register is read, the data from the LSB(Least Significant Bit) to 
the MSB(Most Significant Bit) are output to the TDO pin at each falling edge 
of the TCK pin. 


This JTAG circuitry in this FDC can support the only following three 
instructions by setting the specified data into this Instruction register: 


- Bypass 

- Sample/Preload 

- Extest 

Bits in the Instruction Register 

D2. Di D0 Supported Instructions 
0 0 0 EXTEST 
0 0 1 Bypass (after the Reset condition) 
0 1 0 SAMPLE/PRELOAD 
0 1 1 CLAMP-IO 
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reserved (BYPASS) 
reserved (BYPASS) 
reserved (BYPASS) 
BYPASS 


Poach fed ph fee 
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8.4.2.1 Bypass Instruction 


This instruction, which is assigned the instruction data "11" or "01", is used 
to select the only Boundary Scan register for the serial access between the TDI 
and the TDO pins in the Shift-DR controller state. 


When this instruction is selected, the operation of this JTAG circuitry does 
not effect on the operation of the FDC. 


During the Test-Logic-Reset controller state, this Bypass instruction is 
selected. 


8.4.2.2 Sample/Preload Instruction 


This instruction, which is assigned the instruction data "10", is used to select 
the only Boundary Scan register and to have a snap-shot of the normal 
operation of the FDC to be taken and examined. The data to be had a snap- 
shot can be latched into the Boundary Scan register. 


When this instruction is selected, the JTAG circuitry can operate the 
following: 


1) The operation of this JTAG circuitry does not give effects on the 
operation of the FDC or on the flow of signals between the FDC pins 
and the on-chip circuitry. 

2) The states of all signals flowing through the FDC pins are loaded into 
the Boundary Scan register on the rising edge of the TCK pin in the 
Capture-DR controller state. In this case, the loaded data can not loaded 
to the input and output pins in the FDC. These only data can be shifted 
toward the TDO pin in the Shift-DR controller state. 


3) Each output bit of the Boundary Scan register can update the data 
from the old data to the already held data on the falling edge of the 
TCK pin in the Update-DR controller state. But these data can not be 
shifted toward the TDO in the Shift-DR controller state. 


8.4.2.3 Extest Instruction 


This instruction, which is assigned the instruction data "00", also is used to 
select the only Boundary Scan register for the serial access between the TDI 
and the TDO pins in the Shift-DR controller state. 
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When this instruction is selected, the state of all signals driven from system 
output pins is completely defined by the data shifted into the Boundary-Scan 
register and change only on the falling edge of TCK in the Update-DR 
controller state. 


When this instruction is selected, the state of all signals received at system 
input pins is loaded into the Boundary-scan register on the rising edge of 
TCK in the Capture-DR controller state. 


8.4.3 Boundary Scan register 
The function of the assigned bits in this register are described in this section. 
This register consists of the following four types of cells: 


Table 8.4-2 Cells Types for Pins 


Cell Type Functions 
I This cell type is for all input pins. 
O This cell type is only for the output pins to be set toa 
logical high or low. 
OZ This cell type is only for DMARQ and INT pins to be 
set to the logical high, low or the high impedance. 
YO This cell type is only for data bus pins. 


The following pins do not have cell type: 
- Digital and Analog Voltage Supplies (VDD, GND, AVDD and AGND) 
- Clock Output Pin (XA2) 
- Analog Pins (LPF1, LPF2, CGP1 and CGP2) 


Because it is meaningless for the voltage supplies to have Boundary Scan 
registers in order to be able to check these pins by checking whether a 
instruction.can be operated or not. 


On the other hand, it also is meaningless for the Analog pins to have 
Boundary Scan registers in order not to be able to output logically. 


The Boundary Scan register for the I typed and O typed cells is consisted of the 
circuitry at the shown in Fig. 8.4.3.1 and Fig 8.4.3.2. 


The Boundary Scan register for the I typed cell is consisted of the circuitry at 
the shown in Fig. 8.4.3.2. As you know from this figure, the input pin is 
directly connected with the internal logic circuit in the FDC. Because there is 
some capabilities for the oscillator not to oscillate the self oscillation when 
the crystal resonator is connected with the XA1 and XA2 pins if some gates are 
inserted between the pin and the internal logic circuitry in the FDC. 
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The Boundary Scan register for the OZ typed cells is consisted of the circuitry 
at the shown in Fig. 8.4.3.3. In this typed cell, the two registers are for the data 
to be output from the pins and the signal to enable the pins to be output. 
These OZ typed cells are adapted to the only DMARQ and INT pins. 


The Boundary Scan register for the I/O typed cells is consisted of the circuitry 
at the shown in Fig. 8.4.3.4. In this typed cell, the three registers are for the 
data to be output from the pins to the internal circuitry in the FDC, the signal 
to enable the pins to be output and the data to be input from the pins to the 
internal circuitry in the FDC. These I/O cell types are adapted to the only 
from DBO to DB7 pins. 


to the next call 
pin so 
©) PO PI from the internal logic 
SI 
from the previous cell 


typed O cell for all output pins 
Fig 8.4.3.1 the O typed cells 


pin 






to the internal logic 
to the next cell 


PI PO 


from the previous cell 


Fig 8.4.3.2 the | typed cell 
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to the next cell 


VDD 






Enable signal 
from the internal jogic 


pin 


Data signal 
from the internal logic 


from the previous cell 


Fig 8.4.3.3 the three states typed cell 


to the next cell 








input data signal 
to the internal logic 


Enable signal 
from the internal logic 


Output data signal 
from the internal logic 
from the previous cell 


Fig 8.4.3.4 the I/O typed cell 
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Bit # 


Di 


D3 


D5 


D7 


D8 


D10 
Di1 
D12 
D13 
D14 
D15 


D16 
D17 
D18 
D19 
D20 
D21 
D22 
D23 


D26 
D27 
D28 
D29 


Function 
Data to be output from the DEN1_B 
Data to be output from the DEN0_B 
Data to be output from the SEL (HDLD_B) 
Data to be output from the DS3_B 
Data to be output from the INDEX_B 
Data to be output from the DSO_B 
Data to be output from the DS1_B 
Data to be output from the DS2_B 


Data to be output from the ME0_B 


Data to be output from the ME1_B 

Data to be output from the CAO (DIR_B) 

Data to be output from the CA1 (STEP_B) 
Data to be output from the CA2 (SIDE_B) 
Data to be output from the LSTRB-(NC) 

Data to be output from the ENBLO_B (ME2_B) 
Data to be output from the ENBL1_B (ME3_B) 


Data to be output from the WDATA_B 

Data to be output from the WGATE_B 

Data to be output from the (TRKO_B) 

Data to be output from the (WPRT_B) 

Data to be output from the RDATA_B) 

Data to be output from the (DKCG_B / READY_B) 
Data to be output from the PCTYP1 

Data to be output from the PCTYPO 


Data to be output from the DRV2 

Data to be output from the XB 

Data to be output from the XA1 

Data to be output from the ENDKCG_B 
Data to be output from the TC 

Data to be output from the DMARQ 
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Bit # 
D30 
D31 


D32 
D33 


D51 
D52 
D53 
D54 
D55 


D56 
D57 
D58 
D59 


Function 


Signal to enable the DMAROQ active 


Data to be output from the INT 


Signal to enable the INT active 
Data to be input from the DB7 
Signal to enable the DB7 active 
Data to be output from the DB7 
Data to be input from the DB6 
Signal to enable the DB6 active 
Data to be output from the DB6 
Data to be input from the DB5 
Signal to enable the DB5 active 
Data to be output from the DB5 
Data to be input from the DB4 
Signal to enable the DB4 active 
Data to be output from the DB4 
Data to be input from the DB3 
Signal to enable the DB3 active 
Data to be output from the DB3 


Data to be input from the DB2 
Signal to enable the DB2 active 
Data to be output from the DB2 
Data to be input from the DB1 
Signal to enable the DB1 active 
Data to be output from the DB1 
Data to be input from the DBO 
Signal to enable the DBO active 


Data to be output from the DBO 
Data to be input from the A2 
Data to be input from the Al 
Data to be input from the AO 
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Bit # Function 


D60 Data to be input from the CS_B 

Dé61 Data to be input from the WR_B 
D62 Data to be input from the RD_B 
D63 Data to be input from the DMAAK_B 
D64 Data to be input from the RESET 
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3) DUMP AFTER DATA ADDRESS MARK 


When the RDM bits are set to "10", this mode can be entered under the 
only Apple mode. 


This dumps the requested number of bytes from the specified track. 
Especially under the MFM format, after the FDC finds out the specified 
ID address mark, the Data Address mark of this specified ID field and 
then the nearest SYNC bytes, the FDC checks whether the next data after 
these SYNC bytes is equal to the Mark byte, which is expected as the $A1 
for Data byte and the $0A for Clock byte. If this mark is hit, the FDC 
should start to dump data from and including this Mark byte. But if the 
Mark byte can not be hit, the FDC changes the expected Data for the Mark 
byte from the above data to the $C2 for Data byte and the $14 for Clock 
byte and then the FDC resumes to search the same specified ID field. 
After the FDC finds out the specified ID address mark and then the 
nearest SYNC bytes, the FDC checks whether the data after these SYNC 
bytes is equal to the Mark byte, which is expected as the $C2 for Data byte 
and the $14 for Clock byte. If this mark is hit, the FDC should start to 
dump data from and including this Mark byte. But if the mark byte can 
not be hit, the FDC abnormally terminates the command and interrupts 
to inform to the host this abnormal termination. 


For GCR format, after the FDC finds out the specified ID address mark 
and then the Data header of this specified ID field, the FDC is waiting to 
received the Mark byte with the $D5 for Data byte. If this mark is hit, the 
FDC should immediately start to dump data from and including this 
Mark byte. But if the mark byte can not be hit, the FDC abnormally 
terminates the command and interrupts to inform to the host this 
abnormal termination. In addition, the FDC dumps the data without 
denibblizing the read-data from the FDD. 


The Fig. 4. 18. 3 is shown as a example of this mode. In this example, the 
ID Address mark is located after the specified ID field, the Data Address 
mark and the SYNC bytes. 


In this dumped mode, the FDC ignores the following errors after the first 
Address mark in the data field is found out. 


- Read error for CRC for the MFM format or Checksum for 
the GCR format 


- Read error for Bit slip byte for the GCR format 
- Read error for Address mark in the Data field 


ID field Data field ———_—_>- 


Sync Address address GAP2 Sync __ data address 
byte mark header byte mark 
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FF [3 [CF [F3 Fo [FF ps Ja fee | tr [5 fear | # fox JOE AA JPF |2F JF [Fs FO IF Ds [AA JAD] « [ XX..X]0E Aa 


ee 


transfered data from this point from 
Fig. 4.18.3 Transferred Data for Dump After Data Address Mark 

















Transferred Data 


FOR MFM FORMAT 
The FDC starts to dump data to the host according to the following 
transfer rule shown in the Fig. 4.18.4 after the mark byte is detected. This 
transfer is called the 8 x 8 data transfer format and the FDC should 
transfer the Data byte and the Clock byte, repeatedly. 

Data from the FDD 
Transferred bytes Data bytes Clock bytes 


#2(Data) 







included 
Missing clock bits 


#3(Data) 
#4(Data) 
#5(Data) 
#6(Data) 
#7(Data) 


included 


#8(Data, 
( Missing clock bits 


Data from the FDC to the host 
#1(Data)  #2(Data) 


A1} OA} A1| 0A’ 





Fig. 4.18.4 The 8 X 8 Data Transfer Format for MFM 


The following charts illustrate the MFM clock byte for the dumped data 
pattern. The chart shows two clock bytes for each data pattern. The clock0 
column illustrates the clock byte if the previous data bit was a "0". The 
clock1 column illustrates the clock byte if the previous data bit was a "1". 


65 


66 


67 


FOR GCR FORMAT 
The FDC starts to dump the raw data from FDD to the host without 
denibblizing, this disables the 3 - 4 conversion process. In addition, the 
data that is transferred from the FDC to the host is in the 8x8 format. The 
difference is that the clock byte that is transferred is a duplicate of the 
data byte. This additional Dummy Clock byte is meaningless. Please refer 
to the following diagram. 


Data from the FDD 
Transferred bytes Data bytes 


Dummy Clock bytes 
#1(Data) 


#2(Data) | —9D— —9D— 
#3(Data) | —A7— —A7— 
rao 
#5(Data) | —FB— —FB— 


recs 
rr 
vom EB) EO 


Data from the FDC to the host 
#1(Data) #2(Data) #3(Data) #4(Data) #5(Data) #6(Data) #7(Data) #8(Data) 


FA[FA] 9D[9D] A7[A7] FELFE] FBL FB] aBL Ap] Bal BA] DD[DD] 
ge ge ga a a ed 


Fig. 4.18.5 The 8 X 8 Data Transfer Format for GCR 


ERROR CONDITIONS 
1) DUMP AFTER THE ID ADDRESS MARK: 
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If the recording format is GCR and the FDC can not find the ID Address 
Mark within the 400msec. 


If the recording format is MFM and the FDC can not find the ID Address 
Mark within two Index pulses. 


2) DUMP AFTER THE DATA ADDRESS MARK: 


If the recording format is GCR and the FDC can not find a Data Address 
Mark within the 400msec. 


If the recording format is MFM and the FDC can not find the Data 
Address Mark within two Index pulses. 


3) WHEN THE FOLLOWING CONDITIONS OCCUR: 
- The overrun or underrun occur during the data transfer. 
- The TC does not be input for the allowable period. 


- Under Standard modes, the READY_B pin in the drive interface is 
inactive before this is operated under Standard modes. 
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Under Standard modes: 


This command is similar to the above function under the Apple mode, 
except that this is a continuous read operation from the data field of the 
sectors immediately after the Index pulse. 


PARAMETERS IN THE RESULTANT PHASE 


*1) # OF SECTOR TO BE READ 


For Apple mode, this byte indicates the number of remaining sectors to 
be read when this command has failed by some error. 


# of Sector to be Read" (Resultant Phase) = # of Sectors to be Read - # of 
Sector Read" 


For example, the host has set 5 to the byte "# of Sectors to be Read" in the 
Command Phase. When the FDC detects some error while it is reading 
the third sector to be read (after the first and second sectors were 
successfully read), the FDC reports in the resultant phase that this "# of 
Sector to be read" byte is set "3" ( 5-2). 


The parameters in this command are same functions as the Read Data 
Commands except the parameters specified above. 


ERROR CONDITIONS 


1) When the FDC can not find the following within 400msec for the GCR 
format, or when the FDC can not find the following before two Index 
pulses are detected for MFM and FM format: 


- Address mark in the Address header ( ID field) 
- Desired Address header ( Data in the ID field ) 


2) When the FDC detects a Read Error in the following: 
- CRC bytes or the Checksum bytes 
- Address Mark in the Data field 
- Bits slip bytes (Under GCR format only) 


3) When the following conditions occur: 
- Overrun or Underrun occur during Data transfer. 
- When utilizing the TC input, it does not meet the correct 


timing period. 
- Under Standard/Apple mode, when the status of the FDD 
indicates a NOT READY condition prior to command execution. 
- Under Standard modes, when the DDAM (Deleted Data 
Address Mark) is detected, the CM bit of the Status Register 2 
(ST2) is set. and one of the following two conditions occur 
according to the contents of the TB bit in the command phase. 
(1) When TB=0: command execution terminates 
normally after data transfer of that sector. The ID bytes of 
the sector in which DDAM is detected will be the value in 
the result phase. 
(2) When TB=1: the sector is skipped and the next sector is 
read. 


4) When the FDC continues to read even if the following errors occur: 


- The CRC bytes or the Checksum bytes 
- The Bits slip bytes (only under GCR format) but the FDC will 
mark the error in the Status register 0-2 at the result phase. 
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Read Data 


__Prese__| aw D7 Dé DB D4 D3 D2 D1 D9 


MIT FM TB O O 1 command code 
Xx X X X X ees 
Cylinder 
Head 
Sector 





(Bytes/Sector) / Format Byte 
Last Sector in Muliti Sector Read 


SszszzzzzzeEe 





GSL(MFM) / don't care (GCR) 
Data Length in Bytes 


i 
Host and FDD 
Status Regisiter 0 status information 
Status Regisiter 1 after this command 
Status Regisiter 2 
Cylinder 
Head 
Sector 
Bytes/Sector) / Format Byte 















FUNCTION 

GENERAL: The host can use this command to read the data in the Data 
field from the specified sector. After this command has been issued, the 
FDC begins reading ID address header (or data in the ID field). 

When the specified sector number equals the sector number read off the 


disk, the FDC transfers the data from the Data field byte by byte via the data 
bus. 


After completion of this operation from the current sector, the internal 
sector number is incremental by one, and the data from the next sector is 
read and output on the data bus. 


MULTI-TRACK READ: If the MT (Multi-track) bit is set, the read will 
continue with data on the other side of the disk, for the specified cylinder 
only. 


TAG BYTE FOR THE ONLY GCR FORMAT: 
While in the GCR format, the FDC will ignore the Tag bytes at the 
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g of the sector, unless the TB bit is set to high(1). When the TB bit 
is set to high(1), the FDC will transfer 524 bytes to the host. If the TB bit is 
not set, the FDC will transfer only the 512 data bytes of the sector. 


PARAMETERS 
a.) GCR format: 
The values for the EOT (Last Sector in the Multi-sector Read) and N 
(bytes/sector) should be set as: 
N should be set as 02H, 22H, or 24H 
EOT should be set from 8H to CH 
b.) MEM or FM format: 
The reference value for the EOT, N, and GSL are shown in Table 4.8.1 


peels [ome | aoe 


ee 
1.2MB 
1.44MB 
2.88MB 

IBM diskette 2D 


ISM diskette 1 
IBM diskette 2 





Table 4.8.1 Reference Values for N and EOT 


DATA LENGTH IN A SECTOR: 

For Standard modes, only when the "Number of data bytes in the Sector" 
byte ( N ) is Zero for the FM format, this data length in the sector is 
determined by the "Data length in bytes" byte (DTL). This "DTL" should be 
set the less than 80H and 128bytes/sector is specified when this "DTL" is set 
the bigger than 80H. 

When the "Number of data bytes in the Sector" byte ( N ) is not zero, this 
data length is determined by the only "Number of data bytes in the Sector" 
byte ('N ) (see the above table 4.8.1). 
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NORMAL TERMINATION 


When this command normally terminates, the values in Table 4.8.1 are 
set at the resultant phase: 


Head last ID information at the result phase 
sector | cylinder | Head | Sector | oN | 
0 0 NC NC 


NC 


NC 
NC 


NC 
NC 
NC 
NC 
NC 





Table 4.8.1 Normally Terminated Values for Read Data Command 


NC No Change 
EOT Maximum number of sectors to be written on the disk 


LAST SECTOR Number of the "last sector in the Multi sector read” byte at 
the command phase 


Cc Number of the "Cylinder" bytes at the command phase 
S Number of the "Sector" bytes at the command phase 
N "Number of data bytes written” at the command phase 
PARAMETERS 

FM Under Apple mode, this bit indicates the following 


format mode: 
MFM format mode, when this bit is set. 
GCR format mode, when this bit is reset. 
Under Standard modes, this bit indicates the following 
format mode: 
MFM format mode (when this bit is set). 
FM format mode (when this bit is reset). 


TB Under Apple mode, this bit determines whether the data 
in Tag bytes should be transferred or not. 


Transfers the data (when this bit is set). 
Don't transfer the data (when this bit is reset. 
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MT 


Under Standard modes, this bit determines whether the 
data in the Data field are skipped or not. 

Skips the data (when this bit is set). 

Transfers the data (when this bit is reset). 
Under Standard modes, the issued command requests the 
FDC to perform the Seek command without specially 
issuing the Seek command and then to perform this Read 
Data command, when this bit is set. 


ERROR CONDITIONS 

1) When the FDC can not find the following within the 400msec. in Apple 
mode or when the FDC can not find the following before two Index pulses 
are input for MFM and FM format in standard mode: 


- Address mark in the Address header ( ID field) 
- Desired Address header ( data in the ID field ) 


2) When the FDC detects a read error in the following: 


- the CRC bytes or the Checksum bytes 
- the address mark in the Data field 
- the Bits slip bytes under only GCR format 


3) When the following conditions occur: 


- The overrun or underrun occur during the data transfer. 
- When utilizing the TC input, it does not meet the correct 
timing period. 
~ Under Standard modes, the READY_B pin in the drive 
interface is inactive before this is operated under Standard 
modes. 
- Under Standard modes, when the DDAM (Deleted Data 
Address Mark) is detected, the CM bit of the Status Register 2 
(ST2) is set and one of the following two conditions occur 
according to the contents of the TB bit in the command phase. 
(1) When TB=0: Command execution terminates 
normally after data transfer of that sector. The ID bytes of 
the sector in which DDAM is detected will be the value in 
the result phase. 
(2) When TB=1: The sector is skipped and the next sector 
is read. 
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Read Deleted Data 


Phase | re D7 D6 DS 4 D3 D2 Dt pd 
1 


MT FM SK 0 1 command code 
X X X X X ans 
Cylinder 
Head 
Sector 
Number of data bytes in the Sector 
Last Sector in Muliti Sector Read 
GSL 
Data Lenath in Bytes 


de 
Host and FDD 
Status Regisiter 0 status information 
Status Regisiter 1 after this command 
Status Regisiter 2 
Cylinder 
Head 
Sector 
Number of data bytes read 

















Stzzzstzzzze= 














FUNCTION 
This command can be used only under Standard modes and can not be 
supported under Apple mode. 


DAM and DDAM explained in the Read Data functions under standard 
modes are replaced with DDAM and DAM, respectively. 


Read ID 


Prose _| a Dz_Dé DS Dé ps 2 1 bo 
0 


command : 7 00 1 0 |command code 
X X X HD ss DRO 


fem | The first correct ID 




















information found on 
the track is returned 

















status information 
after this command 


Status Regisiter 0 
Status Regisiter 1 
Status Regisiter 2 
Cylinder 
Head 







FUNCTION 

The host uses this command to read the present position of the 
Read/Write head of the FDD. The FDC returns the first available address 
header ( or data in the ID field), after a sync byte field, during the result 
phase. 


ERROR CONDITIONS 

FOR MFM FORMAT: 
If the FDC can not find the requested data in the ID field before two 
Index pulses have passed, the FDC will terminate this command and 
inform the host via the status passed in the result phase. 

FOR GCR FORMAT: 
If the FDC can not find the requested address header before two 
revolutions have occurred within 400msec, the FDC will terminate this 
command and inform the host via the status passed in the result phase. 
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Recalibrate 
Phase _| a D7 Ds DS D4 0s D2 D1 D9 


Command 0 0 0O 1 #414 #1 + Jeommand code 
X X X X DR1DRO 
Head is recalibrated 
cylinder 0. 


FUNCTION 

This command causes the FDD to retract the Read/ Write head to Cylinder 
0. 

Under Apple mode: After the FDC receives this command and resets the 
internal parameter of PCN byte: 


(1) The FDC first issues the /Step command toward the outside to the FDD 
for 80 steps and then checks the status of /Track0 from the FDD. 

(2) After the status of /Track0 becomes active, the FDC issues the /Step 
command toward the inside to the FDD until the status of /Track0 
becomes inactive. 

(3) After the status of /Track0 becomes inactive and then the FDC issues a 
/Step command toward the outside to the FDD, the FDC confirms the 
active status of /Track0. 

(4) The interrupt (INT) is asserted to inform of the host about the 
termination of this command. 

(5) Finally, the result for this command is reflected in the Status Register 0 
(STO) and this STO should be read by issuing the Sense Interrupt Status 
command. 






Under Standard modes: After the FDC resets the internal parameter of 
PCN byte, a Seek Operation is performed toward the outside until TRKO_B 
signal in the drive interface becomes active. 

When the TRKO_B signal becomes active, the SE bit in the Status Register 
0 is set and the command execution is normally terminated. However, 
this Status Register 0 should need to be read by issued the Sense Interrupt 
Status command. 


ERROR CONDITIONS 
UNDER APPLE MODE: 


The FDC informs the host of a abnormal terminations by setting the INT 
pin active after the EC bit in the Status register 0 in the result phase is set. 


(1) The FDC first issues the /Step command toward the outside to the FDD 
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for a maximum of 80 steps, the FDC can not check the active status of 
/Ready in the drive interface within 800msec after the last /STEP 
command is issued. 

(2) After the FDC checks the active status of /Ready in the drive interface 
within 800msec after the last /STEP, the FDC can not check the active 
status of /Track0 in the drive interface. 

(3) After the status of /Track0 becomes active and the FDC issues the /Step 
command toward the inside to the FDD for a maximum of 80 steps, the 
FDC can not check the inactive status of /Track0. 

(4) After the FDC issues a /Step command to the FDD in the above 
sequence, the FDC can not check the active status of /Ready in the drive 
interface within 18msec. 

(5) After the status of /Track0 becomes inactive and then the FDC issues a 
/Step command toward the outside to the FDD, the FDC can not 
confirms the active status of /Track0. 

(6) After the FDC issues a /Step command to the FDD in the above 
sequence, the FDC can not check the active status of /Ready in the drive 
interface within 18msec.. 


UNDER STANDARD MODE: 

(1) When the TRKO_B signal does not become active after issuing the 
maximum of 80 steps to FDD, the FDC sets the SE and EC bits in the 
Status register 0. 

(2) When the READY_B signal becomes inactive during the execution 
phase, the FDC sets the SE and NR bits in the Status register 0. 


Relative Seek 


| Phase | Rw| D7 Dé D5 D4 D3 D2 D1 D9 


1 DIR 0 01 1 command code 

X X X X X ee 
Head is positioned 
over relative cylinder. 


Relative cylinderNumber 
FUNCTION 


This command is used under Standard modes. The FDC relatively seeks 
the Read/Write head to the destination cylinder according to the number 
of the "Relative cylinder Number" byte. The direction is defined by the 
DIR bit. 











Revision 


| Phase_| aw! D7 be D5 Dé DS D2 Dt Dd 
feommand | W{ 0 0 1 0 0 0 0 0 |commandcode | 


D7 D6 D5 D4 D3 D2 D1 DO command code _ back the revision 
of installed Firmware. 
Echo back the revision 
| Resut | F | Oe Peer pee ee of installed Hardware. 


FUNCTION 


Under all modes, the result of this command indicates the revision 
number of both the firmware and hardware installed into this FDC. The 
number starts from the zero to "FF". 

The Operating System can easily know what number the installed 
firmware is running in the FDC. 










ERROR CONDITIONS 
There are no error conditions for this command. 
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Scan Equal 


| Phase__| Rw| D7 D6 D5 D4 D3 D2 D1 D9 





WiMTFMSK 1 0 0 0O command code 
WwiX X X X X Hd ORI = 

WwW Cylinder 

W Head 

W Sector 

W jNumber of data bytes in the Secto 

. Last Sector in Muliti Sector Read 






es 


data transfer between 
Host and FDD 


Status Regisiter 0 Status information 








Status Regisiter 1 after this command 


Status Regisiter 2 
Cylinder 
Head 
Sector 
Number of data bytes read 









FUNCTION 
This command is used under Standard modes. This has the same function 
as the Read Data command. 
Data Comparison 
When a data byte transferred from the host is set to FFH, the FDC does 
not compare with a data from the FDD. (It is assumed to be equal.) 
Comparison Method 
A check is made to see if the data byte string on the sector to be 
compared is equal to the system data string. If equal, command 
execution terminates normally. 


MSB 
DISK Data Address Mark 01 02 03 FF 05 06 -------- FE 
HOST 01 02 03 FF 05 06 -------- FE 
1—> Disk=host (not compared) 
Fig. 4.22.1 
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SECTOR UPDATE 


When a data string on one sector is compared with the host data string 
and the comparison condition is not satisfied, the internal sector 
number (S) to be found out is updated ( S <-- S + STP, where STP 
should be 1 or 2), and the data string on the sector specified in the sector 
number is compared with the host data string. Therefore, the host 
should send the same data string repeatedly for each sector. 


STP 


The STP parameter should be set to 01H or 02H. When it is set to 02H, 
the sector number (S) and the Last Sector in Multi Sector Read (EOT) 
must be set so as to satisfy the following expression: 
S + 2(n-1) = EOT 
Where n is the number of sectors to be read. 


EXECUTION TERMINATION 


When a comparison is made on a sector and if the sector satisfies the 
comparison condition, then command execution terminates normally. 
If the equal condition is satisfied, SH bit in the Status register 2 (ST2) is 
set. When there are no sectors satisfying the comparison condition 
although a comparison is made from the first to last sector, the SN bit 
in the Status register is set and command execution terminates 
normally. 


Scan High or Equal 


| Phase | pw| D7 D6 D5 b4 bs b2 D1 pe 


command W | MT FM SK 1 1 command code 
X X X X X eee 
Cylinder 
Head 





Sector 
Number of data bytes in the Sector 
Last Sector in Muliti Sector Read 
s 






a a 





i 
Host and FDD 
Status Regisiter 0 status information 
Status Regisiter 1 after this command 
Status Regisiter 2 
Cylinder 
Head 
Sector 
Number of data bytes read 














FUNCTION 
This command is used under Standard modes. This command has the 
same function as the Read Data command. 
Data comparison 
When a data byte transferred from the host is set to FFH, the FDC does 
not compare with a data from the FDD. (It is assumed to be equal.) 
Comparison method 


When the data byte string on the sector to be compared is greater than 
or equal to the host data string, command execution terminates 


normally. 
MSB 
DISK Data Address Mark 01 02 03 44 05 06 -------- FE 
HOST 01 02 03 40 05 06 -------- FE 
1--> Disk>host (compared) 
Fig. 4.24.1 


SECTOR UPDATE 


When a data string on one sector is compared with the host data string 
and the comparison condition is not satisfied, the internal sector 
number (S) to be found out is updated ( S <-- S + STP, where STP 
should be 1 or 2), and the data string on the sector specified in the sector 
number is compared with the host data string. 

Therefore, the host should send the same data string repeatedly for 
each sector. 

STP 


The STP parameter should be set to 01H or 02H. When it is set to 02H, 
the sector number (S) and the Last Sector in Multi Sector Read (EOT) 
must be set so as to satisfy the following expression: 
S + 2(n-1) = EOT 
Where n is the number of sectors to be read. 


EXECUTION TERMINATION 


When a comparison is made on a sector and if the sector satisfies the 
comparison condition, then command execution terminates normally. 
If the equal condition is satisfied, SH bit in the Status register 2 (ST2) is 
set. When there are no sectors satisfying the comparison condition 
although a comparison is made from the first to last sector, the SN bit 
in the Status register is set and command execution terminates 
normally. 
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Scan Low or Equal 


| Phase _| RW| D7 D6 D5 D4 DS pap os 


MT FMSK 1. 1 command code 
Xx X X X X nes 
Cylinder 
Head 
Sector 









Number of data bytes in the Secto 
Last Sector in Muliti Sector Read 







GSL 





STP 
data transfer between 
Host and FDD 





Status Regisiter 0 status information 
Status Regisiter 1 after this command 
Status Regisiter 2 
‘Cylinder 
Head 
Sector 
Number of data bytes read 
















FUNCTION 
This command is used under Standard modes. This command has the 
same function as the Read Data command. 
Data Comparison 
When a data byte transferred from the host is set to FFH, the FDC does 
not compare with a data from the FDD. (It is assumed to be equal.) 
Comparison Method 
When the data byte string on the sector to be compared is less than or 
equal to the host data string, command execution terminates normally. 


MSB 
DISK Data AddressMark 01 02 03 04 05 06 -------- FE 
HOST 01 02 03 40 05 06 -------- FE 
1—> Disk<host (compared) 
Fig. 4.23.1 
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SECTOR UPDATE 


When a data string on one sector is compared with the host data string 
and the comparison condition is not satisfied, the internal sector 
number (S) to be found out is updated ( S <-- S + STP, where STP 
should be 1 or 2), and the data string on the sector specified in the sector 
number is compared with the host data string. Therefore, the host 
should send the same data string repeatedly for each sector. 

STP 


The STP parameter should be set to 01H or 02H. When it is set to 02H, 
the sector number (S) and the Last Sector in Multi Sector Read (EOT) 
must be set so as to satisfy the following expression: 
S + 2(n-1) = EOT 
Where n is the number of sectors to be read. 


EXECUTION TERMINATION 


When a comparison is made on a sector and if the sector satisfies the 
comparison condition, then command execution terminates normally. 
If the equal condition is satisfied, SH bit in the Status register 2 (ST2) is 
set. When there are no sectors satisfying the comparison condition 
although a comparison is made from the first to last sector, the SN bit 
in the Status register is set and command execution terminates 
normally. 
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inform this termination of the host. This status register 0 should be 
read by issued the Sense Interrupt Status command. 

Since the FDC is not busy in the Execution phase, seek or recalibrate 
commands given to other FDDs are accepted and seek operation can be 
performed on up to four FDD at the same time. But Read/Write groups 
commands must not be issued during the seek operation. 


ERROR CONDITIONS 
UNDER APPLE MODE 


If the /Ready line does not become active following a /Step command, 
within the allowable time specified in following table 4.4.1, the FDC will 
terminate this command. Upon termination, the FDC will assert an 
interrupt, set the EC bit in the status register 0 and indicate an abnormal 
termination. The maximum timeout for all possible condition is 800msec. 


Max Waiting Time Conditions 
18msec When the Seek operation to move one track 

without speed block change under GCR and MFM 

250msec When the Seek operation to move one track with 
speed block change (only GCR mode) 

800msec When the Seek operation to move tracks with 
more than two speed block changes under both 
GCR and MFM 


Table 4.4.1 Allowable Waiting Time for /Ready Status after /Step 
Command is Issued 


UNDER STANDARD MODES: 


When the READY_B signal becomes inactive during the execution phase, 
the FDC sets the SE and NR bits in the Status register 0. 
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Sense Drive Status 


|_Phase__| RW| D7 D6 DS D4 DS D2 D1 DO 
0 0 0 0 0 1 +O O |command code 
X X X X X HD DR DRO 
Status Register 3 Status information 
for FDD . 


FUNCTION 
This command reports the status of the FDD by reading the Status Register 
3 (ST3) from the Data register. 






PARAMETERS IN THE RESULTANT PHASE 
Under Apple mode: 
The Status Register 3 (ST3) is shown in the following diagram: 


D7____D6 D5___—D4 D3 D2 D1 DO 
Media WP RY TO DRIVE MODE SELMEDIA MFM 


Status Register 3 (ST3) under Apple Mode 


MEDIA ___ Reflects the /2MB or /4MB media status from FDD 


WP Reflects the /WRTPRT status from FDD 

RY Reflects the /READY status from FDD 

TO Reflects the /TKO status from FDD 

DRIVE Reflects the 2MB-4MB Drive status from FDD 
MODE Reflects the /Mode ID status from FDD 


SEL MEDIA Reflects the /Select Media status from FDD 
MFMM Reflects the /MFM mode status from FDD 


Under Standard Modes: 
The Status Register 3 (ST3) is shown in the following diagram: 


D7_ Dé D5 D4 D3 D2 Di DO 


0 WP RY_ TO 1 HD DRI DRO 
Status Register 3 (ST3) under Standard Modes 
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WP Reflects the state of the WPRT_B pin in the drive 


interface 
RY Reflects the state of the READY_B pin in the drive 
interface 
TO Reflects the state of the TRKO_B pin in the drive interface 
HD Reflects the 


DR1, DRO Reflects the 


ERROR CONDITIONS 
There are no error conditions for this command under both Apple and 
Standard modes. 


Note: Under Apple mode only, this command should be issued to get the 
correct status from the FDD only after the "Set Enable Control” command 
is issued. In the other word, if this command is issued to the FDC more 
than one time after the "Set Enable Control” command is issued, the FDC 
can not correctly inform to the host the content of the Status register 3 
(ST3) at the result phase. Because the specific FDD of Apple has the same 
codes between the Motor off and the Select Media command to the FDD. 
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Sense Interrupt Status 


a D7 DS DS Dé D3 p2 Dt pd 









| 0 0 0 01 0 0 0| 0 0 O 0 O O {command [command code | 
ExREEREEE Register 0 connane for Interrupt 
Present CylinderNumber 


FUNCTION 


By using this command, the host can check why the FDC has interrupted 
the host. The interrupts between Apple and Standard operation modes 
occur for different reasons. 


Under Apple mode: 


(1) Upon entering the result phase of any commands that passes back some 
status information. 


(2) End of Seek and Recalibrate commands. 
(3) End of the following commands: 


- Disable/Enable DPLL - Set Drive Mode 
- Set Motor Control - EJECT Command 


The host should issue this command to the FDC within 100ms after the 
above interrupt occurs. Unless this command can not be issued within 
this 100ms, these maybe be some capability to miss the already occurred 
interrupt. 

(4) During the execution phase in the non-DMA transfer mode to request 
more data 

(5) /CSTIN status bit from the FDD changes status. 

(6) The FDC interrupts when the FDC detects the issued command was 
invalid. In this case, the host should read the only Status register 0 from 
the FDC because the FDC can not set the "Present Cylinder Number” 
(PCN) byte. 


Under standard modes: 


(1) Upon entering the result phase of any commands that passes back some 
status information. 


(2) The status of READY_B signal in the drive interface is changed for the 
target of the standard FDDs. 


(3) End of Seek and Recalibrate commands 


93 


(4) During the execution phase in the non-DMA transfer mode to request 
more data 

(5) The FDC interrupts when the FDC detects the issued command was 
invalid. In this case, the host should read the only Status register 0 from 
the FDC because the FDC can not set the "Present cylinder Number" 


byte. 


Talking about the result parameters, this command has two types of result 
parameters after the FDC suddenly interrupts to the host and then the host 
issues this command to the FDC. 


- One Byte Parameters 
- Two Byte Parameters 


One Byte Parameters 


Regarding one byte parameter in the result parameter, this case occurs 
after the following: 

- The FDC interrupts to the host to inform to detect the status of the 
target FDD in the polling routine to be waiting for the issued 
command. Especially, this status means the /CSTIN status from the 
FDD during the Apple operation mode and the READY_B pin during 
other operation modes. 

- The host issues the Sense Interrupt Status command to the FDC after 
the interrupts for the following command occur. 
- Disable/Enable DPLL - Set Drive Mode 
- Set Motor Control - EJECT Command 

- The host issues the Sense Interrupt Status command to the FDC in 

spite of not interrupted by the FDC. 


Two Byte Parameters 


Regarding two byte parameters in the result parameter, this case occurs 
after the following: 
- The FDC interrupts to the host to inform to detect the termination of 
the Seek or Recalibrate command. 


How to Receive Parameter in the Result Phase 


The host should know how may bytes should be received from the FDC at 
the result phase of the Sense Interrupt Status command by checking the 
first byte at this result parameter. If this first byte indicates either the 
changed status for the target FDD or the invalid command received from 
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the host, the host should read only one byte from the FDC at this result 
phase. 


On the other hand, if this first byte indicates the termination of either the 
Seek or Recalibrate command, the host should read only two byte from 
the FDC at this result phase. 


ERROR CONDITIONS 


There are no error conditions for this command under both Apple and 
Standard modes. 
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Set Enable Control 


Phase _| RW | D7_D6 D5 D4 D3 D2 D1 DO 
command EN 0 0 1 1 0 1 1 | command code 
X X X X X X X DR 
Sets or resets Enable 
Pin according to 
specified value. 


FUNCTION 
Under Apple mode only, this command is used to turn on or off the 
Enable Pin of the specified drive. Once the ENBL_B pin is set active by 
this command, the ENBL_B pin keeps the same state until this command 
makes this ENBL_B pin inactive. Only after this command is issued to 
reset the ENBL_B pin to inactive while this pin is active, this pin is then 
reset to inactive. 
On the other hand, Immediately after asserting or deasserting the ENBL_B 
Pin of the specified FDD, the FDC will issue a normal termination 
interrupt to the host. 
Note that the ENBL_B Pins of two FDD's can not be set to active at the 
same time by using this command. In addition, the host should remember 
which ENBL_B Pin is active because the FDC does not save the status for 
which FDD is enabled. 
Regarding the polling sequence, the FDC can not poll the status for the two 
FDD's while one ENBL_B Pin is active after this command is issued. This 
means that the FDC can not detect the event that the media is inserted 
into another FDD while the ENBL_B Pin is active on another drive. 
After the ENBL_B Pin is reset to inactive by issuing this command, the 
FDC can then detect that the media is inserted into another FDD. 







PARAMETERS 
EN =1 The ENBL_B Pin of the FDD specified by the DR bit in the 
second byte is set to the active state. 
EN =0 The ENBL_B Pin of the FDD specified by the DR bit in the 
second byte is reset to the inactive state. 


ERROR CONDITIONS 
This command checks no status of the specified FDD therefore this 
command has no error conditions and the FDC always informs the host of 
a normal termination. 
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Set Drive Mode 
! pw| D7 D = aes "2 Di DO 
ame 0 0 0 0 |command code 
X - X : . X DR 


Sets drive mode to GCR 
or MFM via the /MFM 

command according to 
specified value. 















FUNCTION 

Under Apple mode only, this command is used to set the drive to either 
GCR or MFM mode. This is done by writing the /MFM mode control bit in 
the specified drive. After the /MFM command has been sent to the FDD, 
the FDC will monitor the /Ready status line to determine whether this 
command was completed or not. At the completion of the command, the 
FDC will issue a normal termination interrupt. 


ERROR CONDITIONS 


If the /Ready line is not asserted within 800msec after the command is 
asserted, the FDC should abort the command and issue an interrupt. 
When the interrupt is asserted, the FDC should mark the command as 
abnormally terminated and assert the EC bit in the Status register 0 (STO). 
The host will then issue a Sense Interrupt Status command to be read the 
EC bit. 
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Set Motor Control 
| Phase _| RW| D7 D6 D5 D4 D3 D2 D1 DO 
MO 0 0 1 1 =O 1 OQ command code 
Xx X X X X X X DR 
: Sets /MOTOR ON 
specified value. 


FUNCTION 

Under Apple mode only, this command is used to turn the FDD motor on 
or off. This is done by writing the /MOTOR ON mode control bit in the 
specified drive. After the /MOTOR ON command has been sent to the 
FDD, the FDC will monitor the /READY status line to verify that the 
command was completed. At the completion of the command, the FDC 
will issue a normal termination interrupt. 











MO = "0" Motor OFF 
MO = "1" Motor ON 
ERROR CONDITIONS 


If the /Ready line is not asserted within 1 second after the command is 
asserted, the FDC should abort the command and issue an interrupt. 
When the interrupt is asserted, the FDC should mark the command as 
abnormally terminated and assert the EC bit in the Status register 0 
(STO). The host will then issue a Sense Interrupt Status command to 
be read the EC bit. 
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Specify 


| Phase | pw| 07 D6 D5 D4 bs D2 Di po 


cme 000000 command code 


Step rate | Head fees 
FUNCTION 


Head load IND 
The Specify command is used to specify the initial values for several 
configuration parameters. There is no result phase and no error condition 
for this command. 









PARAMETERS 


STEP RATE 
Under Apple mode, it is not necessary to specify the Step Rate, because 
the STEP command is fully handshaked with the FDD. 
Under other modes, this Step Rate specifies the following interval of the 
step pulses generated by Seek, Recalibrate and Relative commands: 


* for 2DD FDD with 250kbps TSRT = 2msec 

* for 2DD FDD with 300kbps TSRT = 1.67msec 
© for 2HD FDD TSRT = Imsec 

¢ for 2ED FDD TSRT = 0.5msec 
e for 2TD FDD TSRT = 0.4msec 


Step Rate(16) Step Rate(16) 
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HEAD UNLOAD TIME 
Under Apple mode, it is unnecessary to specify this Head Unload time. 
Under other modes, this Head Unload specifies the following time to set 
the read/write head to unloaded state after the Read/Write group 
commands is executed: 


* for 2DD FDD with 250kbps THUL = 2msec 
* for 2DD FDD with 300kbps THUL = 1.67msec 
* for 2HD FDD THUL = Imsec 
* for 2ED FDD THUL = 0.5msec 
* for 2TD FDD THUL = 0.4msec 
ft ve] iw | fo ese] te 









Inhibited 
32*THUL 
48*THuL 
64*THuL 
80*THuL 
96° THuUL 

112°T Hut 





HEAD LOAD 
Under Apple mode, it is unnecessary to specify the Head Load time. 
Under other modes, this Head load specifies the following stabilizing 
time of the read/write head after loading at the start of the Read/Write 
group commands: 


¢ for 2DD FDD with 250kbps THLD = 2msec 

¢ for 2DD FDD with 300kbps THLD = 1.67msec 
* for 2HD FDD THLD = Imsec 

¢ for 2ED FDD THLD = 0.5msec 


° for 2TD FDD THLD = 0.4msec 
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Head a | time | Head —— | time | 





















Inhibited 16°THip 
2*THLD 18°THLD 
4°THLD * HLD 
6*THLD " HLD 
8*THLp * HLD 

10°THip 250° Trip 

14*Tutp 254" TLD 


ND_ The ND (Non-DMA) field, when set to 1, specifies that the FDC 
will transfer data to the host in interrupt mode under all 
operational modes. 
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Write Data 


| Phase | aw| 07 Dé DS D4 pa.p2p1p0| __pemats | 
MT FM TB O 


Command command code 















X X X X : ee 
Cylinder 
Head 
Sector 
(Bytes/Sector) / Format Byte 
Last Sector in Multi Sector Write 
GSL(MFM) / don't care(GCR) 








ZStzzzzzze 











Data Length in Bytes 
data transfer between 
Host and FDD 





Status Regisiter 0 status information 

Status Regisiter 1 after this command 
Status Regisiter 2 
Cylinder 













FUNCTION 

The host can use this command to write sector data to the specified sector. 
After this command has been issued, the FDC begins reading the address 
header (or ID field). When all four bytes loaded during parameters, 
cylinder, head, sector and Number of data bytes in the sector, written at the 
command phase match the four bytes of the address header (or the ID 
field) from the disk, the FDC takes data from the processor byte-by-byte via 
the data bus and outputs it to the FDD. 

After writing data into the current sector, the specified sector number is 
incremented by one, and the next data field is written into. The FDC 
continues this "Multi-sector write” operation until the issuance of a 
Terminal Count Signal or until the last sector is meet. If the Terminal 
Count Signal is sent to the FDC it continues writing into the current sector 
to complete the data field. If the host asserts the Terminal Count signal, 
while a data field is being written, the FDC will fill the remainder of the 
data field with zeros. 

The Multi-sector Write operation of the FDC must support I:n 
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interleaving on all formats and transfer rates. Multi-sector Write 
operations while recording in GCR can accommodate any interleaving 
including 1:1. (When writing data in GCR, the write-splice occurs after the 
bit-slip bytes) 


TAG BYTES 

For GCR format; 
TB=1 Data in the 12 Tag bytes should be transferred from the host. 
TB=0 Data in the 12 Tag bytes are automatically filled with zeroes. 


ERROR CONDITIONS 


1) When the FDC can not find the following within the 400msec for the 
GCR format, or when the FDC can not find out the following before two 
Index pulses are input for the MFM and FM format. 


- Address Mark in the Address header (ID field) 
- Desired Address header (Data in the ID field ) 
2) When the FDC detects the read error in the following: 


- CRC bytes or the Checksum bytes in the address header (or ID 
field) 


- Bit Slip bytes only under GCR format 
3) When the following conditions occur: 
- WPRT_B pin becomes active 
~ Overrun or Underrun occur during the data transfer. 
- When utilizing the TC input, it does not meet the correct timing 
period. 
- Under Standard modes, the READY_B pin in the drive interface is 
inactive before this is operated under Standard modes. 
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Write Deleted Data 


| phase | Rw] D7 D6 D5 D4 D3 D2 D1 Do 


MT FM 0 O 1 command code 
X X X X X es 

Cylinder 

Head 









Sector 
Number of data bytes in the Secto 
Last Sector in Muliti Sector Read 
GSL 













Data Length in Bytes 


CS) ae a 
Host and FDD 
Status Regisiter 0 status information 
Status Regisiter 1 after this command 
Status Regisiter 2 
Cylinder 
Head 
Sector 
Number of data bytes read 














FUNCTION 


This command is used under Standard modes only and can not be 
supported under Apple mode. DAM and DDAM explained in the Write 
Data functions under standard modes are replaced with DDAM and DAM, 
respectively. 
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Verify 


Phase _| pw DY_DS D5 D4 3 D2 D1 Ds 


MT FM SK_ 1 command code 
EC X X X : . pape 


Cylinder 
Head 
Sector 







Number of data bytes in the Secto 
Last Sector in Muliti Sector Read 


ZeZzetetezzzizée 


GSL 
Data Length in Bytes 


data transfer between 
A 
Status Regisiter 0 Status information 
Status Regisiter 1 after this command 
Status Regisiter 2 
Cylinder 
Head 
Sector 
Number of data bytes read 



















FUNCTION 
This command is used under Standard modes. 


This command has the same function as the Read Data command except 
that the DMA controller is set to the verify mode to transfer no data 
from the FDC to the host and to response the only DMAAK_B signal for 
the DMARQ signal without the active RD_B signal. 
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Version 


ie 2 BT Dé 06 D4 DS D2 D1.D9 






0 0 |0 0 0 100 007 0 0 0 0 lcommand code code 
0 O poe ee 0 0 O commons coe back for this 
command. 


FUNCTION 
This command is used under Standard modes. This command echoes back 


the "90H" at the result phase. 


106 


Chapter 5 Interface Timings 


5.1.1 Host System Interface Timing 


The host system interface timing diagrams for each command are shown 
in Figs.5.1-1 to 5.1-10. On the host side, in Command phase, check that 
RQM=!1 and DIO=0 before writing data; in Result phase, check that RQM=1 
and DIO=1 before reading data. 


The timing of the READ DATA, READ ID, READ A TRACK, and RAW 
DUMP commands are shown in Fig.5.1-1. 


¢ COMMAND PHASE 


With the condition that ROM=1 and DIO=0, the ROM bit is reset when the 
command code is written to the data register of the FDC from the host. 
However, when contents of the data register are transferred to the FDC's 
internal command register, the ROM bit is set again and writing of the 
next parameter will be requested to the host. When the HD,DR1 and DRO 
bits are written from the host, then the ROM bit is reset. When those bits 
are transferred to the FDC'’s command register, the ROM bit is set, and 
writing of the next parameter will be requested. 


The DIO bit remains 0 until the command code and all required 
parameters are written. Consequently, the host monitors the ROM bit for 
when it becomes 1, and writes parameters in sequence in response. 
However, upon receiving the last parameter, the FDC enters E-phase 
without setting the ROM bit. The FIFO is disabled during the command 
phase to retain compatibility with the »PD765, and to provide for proper 
handling of the " Invalid Command " condition. 


e EXECUTION PHASE 


The process differs depending on whether the data transfer mode is the 
Non-DMA mode (interrupt process) or the DMA mode. After reset, the 
FIFO is disabled (FIFO Depth = 1). The FIFO is available only in the 
Execution Phase of the FDCs operation. The CONFIGURE command is 
used to enable the FIFO and also set the FIFO threshold. After reset, each 
data byte is transfered then by an INT or DRQ depending on the DMA 
mode. For more information on DMA modes and FIFO operations, please 
refer to FIFO Operations in section 5.1.2. 

In the interrupt process, first the DIO bits is set to 1, and when the first data 
of the data field read from the disk is set in the data register, the ROM bit is 
set and an INT request is output. After receiving the INT request, the host 
confirms that both the ROM and DIO bits are 1, then reads the contents of 
the data register. When the contents of the data register are read, the FDC 
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resets the ROM bit. In the same way, the data transfer is performed until 
the last data is transferred. When that data is read by the host, the DIO bit 
is reset after reset of the ROM bit. 


When this process is performed in the DMA mode, before entering C- 
phase the host sets the data transfer direction in the DMA controller by 
program. In E-phase, the FDC outputs the DRQ signal each time the FDC 
sets data read from the disk to the data register. Upon receiving the DRQ 
signal, the host carries out the following sequence; it returns the DACK_B 
signal, outputs the RD_B signal, reads the contents of the data register, 
stores the contents in memory, and stops the DACK_B signal. When the 
DACK_B signal is input from the host, the FDC resets the DRQ signal. 


In Execution phase, the RQM and DIO bits remain reset. When the last 
data is transferred, Execution phase terminates. At this time the FDC set 
the result status and the parameters to the internal register, outputs the 
INT signal to request the host to read those data, and enters R-phase. The 
NDM bit(D5) of the status register is then reset. 


e RESULTANT PHASE 


The FDC first sets the DIO bit, and when contents of the STO register have 
been transferred to the data register, the FDC sets the ROM bit and requests 
reading of the contents (the result status STO) of the data register. Upon 
receiving the INT signal, the host confirms that both the DIO and RQM 
bits are 1, then reads the contents (STO) of the data register. When the 
contents of the data register are read, the ROM and DIO bits are reset, then 
the INT signal is reset. After reading the STO, the host waits until the DIO 
and ROM bits become 1, then reads the result status ST1. In this way, when 
all necessary result status (STO, ST1, and ST2) and parameters (C, H, S, and 
N) are read from the FDC, the FDC sets dummy data, then sets the RQM 
bit and waits for the next command. 


The FIFO is disabled during the resultant phase to retain compatility with 
the pPD765. The resultant parameters of the executed command are 
immediately available, without the FIFO. 


The timing of the WRITE DATA, FORMAT A TRACK, and 
FORMAT/WRITE commands are shown in Fig.5.1-2. This timing is the 
same as that of the Read Data group commands except for the different 
data transfer direction (DIO=0) in Execution phase. 

The timing of the SENSE DRIVE STATUS command is shown in Fig. 5.1- 
3. In the Command phase, only the command code and data specified by 
the HD, DR1, and DRO bit are written. There is no Execution phase for this 
command. In the Resultant phase, the INT signal is not output; therefore 
after Command phase, the host side confirms that both the DIO and RQM 
bits are 1, then reads the contents of the ST3 set to the data register and 
terminates command execution. 
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parameters,the FDC clears any. FIFO data to ensure the validity, and enters 
into the execution phase. In execution phase, the FDC can support the single 
and demand transfer, and allow the system some latency defined by threshold 
value When the data transfer terminates normally or abnormally, the FDC 
enters into the result phase.At the beginning of result phase, the INT signal is 
generated. For each command, a defined set of result bytes has to be read from 
the FDC. The result byte may be read from the FDC after RQM=1 and DIO=1 
of status register. When the HOST read the all parameters, the status register 
of FDC becomes RQM=1, DIO+0,CB=0,and result phase end. 


5.1.2 1 FIFO Threshold 


In using the FIFO, the HOST is allowed a large service latency without 
causing a overrun or underrun error. The user can program this latency to 
adjust his purpose. THRESHOLD is defined as the number of available bytes 
to the FDC until the HOST starts to service the data from a FDC request 
(i.e.DMARQ is active). 


ex: FIFO STATES WHEN DMARQ BECOMES ACTIVE (THRESHOLD=2) 


FROM HOST " a 
13 1415 
threshold 
O data exist position 


The FDC takes out data bytes from the FIFO. When two data bytes are left in 
the FIFO, the FDC will activate the DMARQ. and request service from the 
HOST. 


FROM FDC TO aa 
13 1415 


FDC HOST 
Cor 


O dataexist 4 Lie 


The FDC takes data bytes into the FIFO. When the number of data bytes in the 
FIFO is 14 (the open cells are two), the FDC will activate the DMARQ and 
request service from the HOST. 
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Fig.5.1-1 READ DATA, READ ID, READ A TRACK, and RAW DUMP Commands 
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35328 
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6 | 
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ia — “= Sets the ist data 
LS of the data field 
pReceives DIL). 
Receives GSL/* 
BReceives EOT/Bytes(LSB 
B-Receives N/Bytes(MSB) |= 
BReceives S 

Receives H 
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Receives HD and DR(RDM) 
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Data register 
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STITT 


C-phase Command 


Command 
wait 


wait 


Signals INT 
to the 
maln 

system DRQ 






DACK 
Signals “WA a! 
from the © 
main on 
system AD ~t 
I 
= 
YY 
RQM U 
| mT 
© 
Status DIO I "Tl 
, < 
o 
cB il 
3 
bt 3 
9 
vy a 
DD i 
D 
© Oo @ 
og] 888 
qe€<c 
. $8 8 
@| 326 
o} 872 
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a 


C-phase 
Command 


— 
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to the 
main 
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system “AD 
RQM 

| f 

Status DIO | | 
| 

CB 
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Command C-phase E-phase C-phase g Bephase , Command 
wait wait 
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*; This does not exist for RECALIBRATE 


 ©Fig.5.1-5 SEEK and RECALIBRATE commands Fig.5.1-6 SENSE INTERRUPT STATUS command 
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LIL 


Command C-phase E-phase 


wait 


Signals INT 
to the 

main 
system DRQ 


Signals Lg 
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main 


system 
AD 
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1 | 
DIO i | 
Status | | 
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Fig 5.1-7 Disable/Enable DPLL, SET 


DRIVE MODE, SET MOTOR CONTROL 


and Set Enable Control commands 


Command 
wait 
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Fig.5.1-8 CONFIGURE and SELECT 


CAPACITY commands 
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Fig.5.1-9 EJECT DISK command 


Command 
wait 


This signal is set 
immediately. 


C-phase R-phase 
Command —p» 
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system DRQ 
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CB 
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Fig.5.1-10 INVALID command 


5.2 Drive Interface Timing 


Under Apple mode, drive interface side timing diagrams for each command 
are shown from Fig. 5.2-1 to 5.2-10. 


Under Standard modes, the Drive Interface timing is almost the same timing 
as that of the uPD765A. 
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T2T 


' Note *1 { Note “1 
ENBL_B 


LSTRB 















WGATE_B 


WDATA_| 


address 
header 
Gor mel | TL ewe Tg Data syne 
Track format AM cksm cks 
bit slip bit slip 
MFM rafal Fell = —T] GAP 
AM CRC DM 


Note *1 : This signal can be controlled by the only “Set Enable Control" command. 


Fig.5.2-2 WRITE DATA 


coe 


Nate *1 Note *1 


ENBL_B 


pont. ——{_ nator _ erie ROE) (=I) 


INDEX from RDATA_B | 
(for MFM format ) 
WGATE_B 
| 


z 
i 
address i 
t 
£ 









GOR swell ome hs 
Track format AM cksm cks 
bit slip bit slip 
MFM cad elfco eel] —oa—TT GAP 
AM CRC DM 


Note *1 : This signal can be controlled by the only “Set Enable Control* command. 


Fig.5.2-3 FORMAT A TRACK and FORMAT/WRITE 


€cL 


ENBL_B | 


SEL, CA0-2 (/DIRTH /STEP /READY 
ROATA.B forms sTEP )}—{_ ISTEP g (olla ineAey 


LSTRB 


Set Direction Step pulse Step pulse Step pulse last Step pulse 


Note *1 : This signal can be controlled by the only "Set Enable Control" command. 


Fig.5.2-4 SEEK and RECALIBRATE 


bcT 





RDATA 
LSTRB | | 


SELECT MEDIA 


Note *1 : This signal can be controlled by the only "Set Enable Control” command. 


Fig.5.2-5 SENSE DRIVE STATUS 


Fig.5.2-6 SENSE INTERRUPT STATUS 


_ “4 y Note *1 
ENBL_B | | 


SEL, CAO-2 «stn X IREADY 


‘Note *1 : This signal can be controlled by the only "Set Enable Control" command. 
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Fig.5.2-11 Set Motor Control for Motor OFF 





ENBL_B 


DATAB 
LSTRB | | | | 


SELMEDIA /MOTOR OFF 


Fig.5.2-12 Set Enable Control 


y *2 y Note *3 








ENBL_B | | 
SEL, CAO-2  ~=—Not defined Not defined 
LSTRB 





Note *1 : This signal can be controlled by the only "Set Enable Control* command. 
Note *2 : The ENBL_B is set to the active state by the "Set Eanble Control" 
Note *3: The ENBL_B is reset to the inactive state by the “Set Eanble 

Control" 
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COMMAND WAIT STATE 


_ sce TE sincesemeneseeenreenesnemnesmeneeneetensaty : Standard Modes 











Command wai 










<<Head load i= 
Reset HDLD signal 











| “1: Register Set are defined 
es by PC Type Pins = "11" 
(Apple Mode) 






If drive is not 
installed, set Dxi 
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FORMAT A TRACK (GCR Format) 


? 
\/ 










<——_ Write protecr= 


Write self-sync bytes 
ata <—<estin > 
- Address mark 


- Address header {When TB is set to 
- Checksum zero, write Tag byte Se REE 


- Bit siip bytes 

- Self-sector bytes ee auzete 
- Data mark 

- Sector 

- Tag bytes 

- Sector data 

- Checksum 
- Bit slip bytes 























When TB is set to one, 










Abnormal 
termination 






<csiit Ly 
: Y 
Set AT, FIN 


Set INT signal 
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FORMAT/WRITE (GCR Format) 


FORMATMWRITE 
Receives HD, DR 
<—ReEapy 
<Wie pros 

NI 
Write self-sync bytes 










- Address mark 
- Address header 
- Checksum 


















When TB is set to 


















- Self-syne bytes zero, write Ta 
; g byte 
- Data mark 
ean as all zero 
- Tag bytes(transfer) ; 
- Sector data(transfer) vet Eee 


Tag Bytes are 


~ Checksum transfered by host 


- Bit slip bytes 








Abnormal 
termination 






est 
ee — 


Set INT signal 
Send Result status 


Set AT, NR 
UD formatting —icstinN—= 
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FORMAT/WRITE (MFM Format) 


FORMAT/MWRITE 
Receives HD, DR 


<< READY > N 
—<Wiite prota 
" 


Check for Index Pulse 
Preamble formatting 
- SYNC 
















ae” 


ID formatting 

- SYNC 
- ID address mark 
-ID 
-CRC 












Data formatting 
- SYNC 

- Data address mark 
- Data(transfer) 











Abnormal 
termination 


est 


Set INT signal 
Send Result status 


Set AT, NR 
- INDEX address mark <—/cstiN > 
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Check only /CSTIN 


Status check 


Y 
Set INT 





[ Saeco] 
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RAW DUMP 
<ein 


Receives parameters Set AT, FIN 







Y 
<i 
N 
<——ROM-3 > N 
7 *3 °4 
Y 





*1: for GCR format 
*2: for MFM format 
* See Diagrams on 
Following Pages 


*3: for GCR format 
*4: for MFM format 
* See Diagrams on 

Following Pages 


esa 







Set AT, FIN 
an <——_ READY > 
Set INT signal 


Send result status 


Abnormal 
termination 
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RAW DUMP 


*1 : Dump from Address Header (GCR Format) 


DMP from AH 








AM undetectsa= 


Y 
<a 
T| Cee] [ener] 








N<—7ESTIN > 
Nex READY > 
saan] | 


Set INT signal 
Send result status 





Abnormal 
termination 
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RAW DUMP 


*2 : Dump from Address Header (MFM Format) 


DMP from AH 











<a 


Y $Ai for Data byte 
SOA for Clock byte 





$C2 for Data byte 
$14 for Clock byte 









Abnormal 
termination 


\ 
<— READY > 
saan] YY 


Set INT signal 
Send result status 
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RAW DUMP 


*3 : Dump from Data Header (GCR Format) 


DMP from AH 
<A detected 


ee | OK 
‘TT . 
BitSlip OK 


Y 








Set AT, FIN 
; eee 
Set INT signal 


Send result status 


termination 
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RAW DUMP 
*4: Dump from Data Header (MFM Format) 


DMP from AH 


$A1 for Data byte 
$0A for Clock byte 





Transter s 8x 8 data 
Ne 7ESTIN— 


Set AT, FIN 


SetA 


Set INT signal 


Abnormal 


termination Send result status 


Note 1: No set CM bit even if DDAM is detected 
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READ A TRACK (GCR Format) 


READ A TRACK 
Receives HD, DR 











lf checksum is 
NG, set DE. 

lf checksum is 

NG, set DE. 








lf checksum is NG, 
set DD, DE. 


lf checksum is NG, 


Check Bit slip set DD, DE. 





















Abnormal 










<< 1c? => , Update ID termination 
: R is # of 
a remaining Set AT 
sectors 





Ne TCSTIN > 
<TEOT-00 > Set INT signal 
N Set AT, FIN = 
Read next sector ae — READY > 
regardiess of number P 


: 
Skip self-sync 


* : Search the specified sector at first. if it be couldn't find by time out, set ND and terminate. Since 2nd sector, check ID 
and set ND if the ID is NG , and continue the command processing. 


Set AT, NR 
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READ A TRACK (MFM Format) 


Receives HD, DR 
<—T READY > N 
<“Separate D> 











if CRC is NG, 
set DE. 


If CRC is NG, set 
DD, DE. 













Abnormal 
termination 


R is # of 
remaining 
sectors 





Read next sector 
reaardiess of number 


Set INT signal 


* : Search the specified sector at first. If it be couldn't find by time out, set ND and terminate. Since 2nd sector, 
check ID and set ND if the ID is NG, and continue the command processing. 
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READ DATA (GCR Format) 
<TREADY > N 









Set AT, NR 


Set AT, FIN 


Abnormal 
termination 


Set INT signal 
end result statug 
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READ DATA (MFM Format) 


Receives parameters 












D/C : Data/Clock 


Update ID 
Skip GAP3 


Set AT, NR 
SIDE=1,S=1 | | SetEN | | 
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READ ID (MFM Format) 


READ ID 
Receives HD, DR 











<Separate > 
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RECALIBRATE 


[Genero 00 STE pues | 






: MFM 18ms 
GCR 800ms 
:18ms 
<—Kax. 80 timas> 
:18ms 


Set INT 
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SEEK 


SEEK 
Receives NCN 
—<Kin-PCa> 
S Ly 
Set /DIRTN 


M ©1 NCN - PCN! -7 









Wait ips 


Calculate the time out for /READY 


Generate 1 STEP 










<—Time out M4: 48ms, 250ms or 800ms 


:18ms, 250ms or 800ms 


Set INT 
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SENSE DRIVE STATUS 


SENSE DRIVE 
Set /ENBL signal 


Read FDD status bits 
-/2MB or /4MB Media 
-WRTPRT 

--READY 

-(TKO 

-2MB-4MB Drive 

-Mode ID 

-Select Media 

-MFM mode 


Reset /ENBL signal 
Send ST3 



















SENSE INTERRUPT STATUS 















Set INVALID 
Send STO 








Check EC 






If a disk is not in the drive, 
FIN is set. 


if not ready, NR is set. 
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SET DRIVE MODE 


SET DRIVE MODE 
Receives DR 
Receives FM 


Set/reset MFM mode 
signal 


Set 800ms Timer 


Command wait S AT 


SET ENABLE 




























Set or Reset 
ENBL_b Signal 
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SET MOTOR CONTROL 


<< Mo bit 
signal 



























Reset /MOTOR ON 
signal 


/Ready 







Set INT 









Set EC, AT 





SPECIFY 






SPECIFY 
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WRITE DATA (GCR Format) 


Receives parameters 










Write Tag byte a Write Tag byte 
O0 Ox peciied irom Mos) 





Set INT signal 


| SibE=1,S=1_| |_SetEN | 
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WRITE DATA (MFM Format) 


WRITE DATA 
Receives HD, DR 
Y 
<—“Reaby 4 
Wire protei > 
NI 
<—<Separate o> 


D/C : Data/Clock 














Abnormal 
termination 





Set INT signal 
send result status 





SIDE=1, S=1 
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Chapter 7 DC / AC Specification 


Absolute Maximum Ratings 





TA = +25 % 

Supply voltage, Vpp -0.5 to +7.0 V 
Voltage on any pin (except Vpp) -0.5 to Vpp+0.5 V 
Operating temperature, TOpT -10 to +70 % 


Storage temperature, TSTG -65 to +150 % 


Capacitance 
TA = +25°C ; Vpp = OV; f= 1 MHz 








Parameter Symbol! Min’ Max Unit Conditions 

Clock capacitance Cg 20 pF Unmeasured 
—_——OO pins returned to 0 V 
input Capacitance CIN 20 pF 

Output capacitance CouT 20 pF 
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DC Characteristics 
Ta =-10 to + 70 % ; Vpp = +5V 4 10% 


Parameter Symbol Min Max Unit Conditions 

Low-level input voltage Viti -0.5 0.8 V___sCExcept XA1 
Viti 0.5 0.2Vpp V_ XA! 

High-level input voltage ViH 2.2 Vpp+0.5 Vv Except XA1 


Vini  0.8VDD Vpp+0.5 VV XA! 














Low-level output voltage VoL 0.45 VV lor=12mA 
DO0-D7,DMARQ, INT, 
TDO 
Vout 0.45 Vs lop=48mA 
All other outputs 
High-level output voltage VoH 3.0 Vpop Vv loy=-4.0mA 
(Note1) DO0-D7,DMARQ, INT, 
TDO 
Input leakage current Hie +10 HA VIN=VYpp 
-10 pA VIN=0V ; 
Output leakage current lou +10 wA VouT=Vpp. Host I/F 
-10 vA Vour=0.45 V Host VF 
+100 pA VouT=Vpp.FDDIF 
- 100 yA Vour=0.45 V ,FDD UF 
VDD supply current pp 40 mA 
Standby current | pos 100 pA 





Note 1 : All of FDD interface outputs are Open Drain outputs. in PC/AT™ Mode , DMARQ and 
INT outputs become Open Drain outputs. 
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Clock Specifications 
Ta = -10 to + 70 % ; Vpp = +5V + 10% 


Parameter Symbo! Min Typ Max Unit Conditions 





Crystal Resonator Source 


Clock cycle tcyA 41.66 ns XA1,XA2 
(24 MHz) 

Clock cycle permitted +05 % 

Oscillator tks 10 ms 

Stabilization time 





External Clock Fig.1 








Clock cycle tcvA 41.46 41.66 41.87 ns XA1 pin. 
(24 MHz) 
tcYB 63.42 63.82 64.42 ns XB pin. 
(15.6672 MHz) For GCR FDD 
49.75 50.00 50.25 ns XB pin. 
(20 MHz) For 13Mbyte FDD 
Clock high-level width tkKH 12 ns 
Clock low-level width = tkKL 12 ns 
Clock rise time {KR 10 ns 
Clock fall time {kr 10 ns 
Recommended Circuit #1 Crystal Clock Occilistors Recommended Circuk #2 Crystal Resonator 


15.6672MHz 


20MHz 
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AC Characteristics 
Ta =-10 to + 70 G ; Vpp = +5V + 10% 








Parameter Symbol Min Max Unit Conditions 





Host Read Timing Fig.2 




















A0-A2,CS_b,DMAAK_b setup to RD_b active tAR 5 ns 

A0-A2,CS_b, DMAAK b hold from RD_b inactive tra 5 ns —_ 
RD_b active pulse width tRR 50 —oe : 
DATA valid from RD_b active _ tRD 40 ns = 
DATA float delay from RD_b inactive tpF 50 ns ee y= 
DATA hold from RD_b inactive tRDH 5 ns se 
RD_b inactive pulse width tRH 50 ns Sioa 
INT delay from RD_b inactive tRI 50 ns Sree 





Host Write Timing  Fig.3 . 
A0-A2,CS_b,DMAAK_b setup to WR_b active taw 5 ns 























A0-A2,CS_b,DMAAK_b hold from WR_binactive twa 5 ns 
WER_) active pulse width tww sO ns 
DATA setup to WR_b inactive tow 50 ns 
DATA hold from WR_b inactive twD 5 ns _ 
WR_b inactive pulse width tWH 50 ns cae 
INT delay from WR_b inactive tw 50 ns 








1 


wi 


8 








Parameter Symbol Min Max Unit Conditions 





DMA Timing Fig.4 


























DMARQO cycle period tucy 8/DTR ps Note 1 

DMAAK_} active to DMARQ inactive taAM 50 ns a 
RD_b / WR_} active to DMARO inactive tRWM 50 ns : 
DMAAK_b setup to RD_b / WR_b active taRw 5 ns —_ 
DMAAK_b hold from RD_b / WR_b inactive trwa 5 ns ~ 
DMARQ active to RD_b / WR_b active tMRWA 0 ns 7 
TC pulse width tTc 50 ns _——— 
TC activa to DMARQ inactive tT™ 50 ns 

DMAAK_} active pulse width tAA 50 ns a 
DMAAK_b inactive pulse width tal 50 ns = 
DMARQ active to DMAAK_b active tMA 0 ns ae 
DMARQ active to RD_b / WR_b inactive tMAW 65/DTR us Note2 “= 
DMARQ active to TC active tuT 65/DTR ps Note2 an 





Reset Timing Fig.5 
RESET pulse width trRST 170 = tcya Note3 





RESET to control inactive tac: 2 ps 


Note1 : DTR means Data Transfer Rate.For example ,when Data Transfer Rate is 500Kbps, DMARQ 
cycle period is as follows. 
taw = 8/DTR = 8/500 000 = 16 ps 


Note2 : DTR means Data Transfer Rate.This value , 6.5 /DTR , appear Over-Run error timing with the 
FIFO disabled. When the FIFO enabled , add (FiFO-threshold x 8 / DTR) to the this value. 


Note3 : This value include Hardware Reset pulse width , waiting term after the SOFTWARE RESET 
command wrote and waiting term the FOCRST_b bit of Digital Output Register (DOR) activated. 
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Nee A A 
Parameter Symbol Min Max Unit Conditions 





MFM FDD Write Data Timing Fig.6 








WDATA_b pulse width twop 0.125/DTR $s Note 
SIDE_b setup to WGATE_B active tsowe =—«-100 pS 
SIDE_b hold from WGATE_} inactive twGSD 750 ps 


MFM FDD Read Data Timing Fig.7 

















RDATA_»b pulse width tRop 50 ns 

RDATA_b cycle period tRDCY 800 ns 1.25Mbit / sec " 
MFM FDD Control Timing — Fig.8 eee 
DIR_b setup to STEP_B active ipsT OSDIR s : 
DIR_b hold from STEP_B inactive ‘sip «12DTRss - 
STEP_b pulse width tsSTp 3DTR s ; 
STEP_b cycle period tsc 500/DTR s Note2 " 
INDEX_b pulse width tIDx 100 ns ” 





Note1 : DTR means Data Transfer Rate.For example ,when Data Transfer Rate is 500Kbps, WDATA 
pulse width is as follows. 
tWoD = 0.125/DTR = 0.125 /500 000 = 250 ns 
Note2 : DTR means Data Transfer Rate.For example ,;when Data Transfer Rate is S0OO0Kbps, Step 
pulse width is as follows. 
tee = SOO/DTR = 500 /500 000 = ims 
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Fig.1 External Clock 
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Fig.3 Host Write Timing 


Sd 
tWA 
tWH 


> {WD 


ow -—-——> 


: Valid DATA e 


Wi 





Fig.4 DMA Timing 
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Fig.5 Reset Timing 





Fig.6 MFM FDD Write Data Timing 





Fig.7 MFM FDD Read Data Timing 


tRDD 


RDATA 
tROCY 
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7.1 AC Timing Diagrams for the Apple Disk Interface 


READING DRIVE STATUS 


The following timing applies to /DIRTIN, /STEP, (MOTOR ON, EJECT, 2MB DRIVE, 4MB DRIVE, 
Mode ID, RDDATA, /DRVIN, /TACH, or INDEX, /READY, /CSTIN, WRTPRT, /TKO, /2MB MEDIA, 
/4MB MEDIA, MFM MODE. 


ENBL_B 


SEL, CA0-2 SS 


RDATA_B 


T1 T2 T3 


T3: 0.5s max for high impedance state 
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READING RDATA 


READY_B 
T1 
SEL 
WGATE_B 
RDDATA TL 

T4 T2 T3 
TS Té6 

GCR mode 

T1: 0.5ysec max 


T2: 100usec max 

T3: 190,1sec max 

T4: 0.15ysec min, 0.8usec max 
T5: 2,4,6sec nomal 

T6: 100,1sec min 


MFM, 1MB mode 


T1: 0.5usec max 
T2: 100usec max 
T3: 190usec max 


T4: 0.15u:sec min, 0.8usec max 
TS: 2,3,4y:sec normal 


T6: 100usec min 


MFM, 2MB mode 


T1: 0.5sec max 
T2: 100usec max 
T3: 340usec max 


T4: 0.15psec min, 0.8sec max 
TS: 2,3,4sec normal 


T6: 100usec min 


MFM, 4MB mode 


T1: 0.5usec max 
T2: 100usec max 
T3: 340ysec max 


T4: 0.15usec min, 0.8sec max 
T5: 1,1.5,2usec normal 


T6: 100usec min 
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SENDING A CONTROL COMMAND 


ENBL_B 


SEL, CA0-2 


LSTRB 






Latch in the drive f 


T1; 0.5psec min i 
T2: 1.0usec min 
T3: 1.0psec max 
T4: 0.5psec max 
T5: O.5psec min 
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/STEP AND /DIRTIN TIMING 


ENBL_B 
DIRTN_B 


STEP_B 





T1: 1.0ys min 
T2: 0.54s min 
T3: 72us min 
T4: See NOTE 
TS: 37s min 
T6: 0.55 min 


NOTE: It is not allowed to change /DIRTN during head movement or head setting. 
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/STEP AND WGATE TIMING 


WGATE_B 


STEP_B 


T1 
GCR mode 
T1: 190s min 
MFM mode 
(1MB) T1: 190,1sec min 


(2MB) T1: 340psec min 
(4MB) T1: 340,sec min 


/READY FOR TRACK ACCESS 


STEP_B 


READY_B 


Tt: 150psec max. 


T2: 18msec max. to move one track without speed block change 
250msec max. to move one track with speed block change (GCR mode ) 
800msec max. for any case when step pulses are sent at the maximum rate 
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/READY FOR MOTOR-ON OR DISK-IN 


ENBL_B 





MOTOR ON_B 


CSTIN_B a ee 
READY_B | —{ 


T1 14 


T1: 600msec max. 
T2: 0.5usec max. 
T3: 1.0sec max. 
T4: 5usec max. 
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IWGATE, WDATA, AND /ERASE TIMING 


ENBL_B 


T5 
READY_B 


11 
WGATE_B | 


T2 Té6 pal 
ERASE_B 


WDATA z - 7 i a 
(GCR shown ) 
T3 T4 


WDATA 
( MFM shown ) 


Note: ERASE_B is a signal internal to the drive. 


GCR mode MFM; 1MB, 2MB, and 4MB mode 
T1: 0.5 psec min.after stepping 


600msec min.after motor on eG aalsee Mater stepping 


600msec min.after motor on 


T2: Same as T1 T2: Same as T1 
T3: 1.8usec min. T3: 4usec min. 
T4: 2usec min. T4: 2usec min. 
T5: 0.5 psec min. T5: 0.5 psec min. 
T6: Same as TS T6: Same as T5 
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TKO TIMING 





ENBL_B 





DIRTN_B 


STEP_B 


TKO_B 


READY_B 





T1: 3.0msec max. 
Te: 3.0msec max. 
T3: 150psec max. 
T4: 18msec max. 
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ICSTIN AND /MOTOR ON 


MOTOR ON_B 
11 
LSTRB 
for the Ejecting 
T2 
CSTIN_B 
ENBL_B 


T4 


T1: 200msec min. 
T2: 1.0usec min. 
T3: 1.5sec max. 
T4: 150,usec min. 
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MOTOR START 


MOTOR ON 


READY_B 


Motor Speed 
settled in +1.5% Ti 


T1: 600msec max 
T2: tsec max 


174 


SPEED ZONE BOUNDARY CROSSING, MOTOR SPEED 


SETTLING TIME 
STEP_B 
Motor Speed 
settled in+1.5% 
71 
T2 


T1; 250msec max. 
T2: 250msec max. 
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/READY FOR MODE CHANGE 
(MFM TO GCR OR VISE-VERSA) 


ode change 
SEL, CA0-2 eee 
LSTRB 
READT_B 
T2 


TH: 800msec max. 
T2: 20msec max. 


SPECIAL CONDITION FOR INDEX WHEN WRITING DATA 


ey 
SEL, CA0-2 XK inpex Anything but INDEX 


RDATA_B : 


eS een INDEX mW 
ee 
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Chapter 8 JTAG Specification 


8.1 Features 
This JTAG implementation into the FDC has the following features: 
1) Compatibility with IEEE1149.1 JTAG Boundary Scan Standard 
2) Only three Registers: 
- Instruction 
- Bypass 
- Boundary Scan 
(There is no Identification or other Test Data registers in the FDC) 
3) Supports the following instructions: 
- Bypass instruction 
- Sample/Preload instruction 
- Extest instruction 
- No support for RUNBIST, Intest and other instructions 


4) Special pins for JTAG: 
- TCK 
- TMS 
- TDI 
- TDO 
8.2 Block Diagram 


Fig. 8.2 shows the block diagram of this implemented JTAG, which is mainly 
consisted of the TAP controller, the Instruction register, the Instruction 
decoder, the Bypass register and the Boundary Scan register. 


The Instruction register is consisted of the two bits shift registers and the 
instruction data to be written should be transfered through the TDI pin. The 
written data as instruction can determine what register should be selected or 
what a kind of instruction should be operated. 


The TAP controller can change its operated state according to the data of the 
TMS latched at the rising clock of the TCK pin. 


The Bypass register is consisted of one shifted register to be connected between 
the TDI and the TDO pins in the Shift-DR state of the TAP controller and to 
be shifted toward the TDO pin at each the falling of the TCK pin when this 
register is selected during the shift-DR state in the TAP. Especially, when this 
instruction is selected, the operation of this JTAG circuitry does not effect on 


177 


the operation of the FDC. 


The Boundary Scan register is located between the external pins and the 
internal logic in the FDC and this register can latch or load data according to 
the instruction from the TAP controller when this register is selected. 


This register is to be shifted toward the TDO pin at each the falling of the TCK 
pin and to output the LSB (Least Significant Bit) from the TDO pin when this 
register is selected during the shift-DR state in the TAP. Especially, when this 
instruction is selected, the operation of this JTAG circuitry does not effect on 
the operation of the FDC. 


Boundary-scan register 


Bypass MPX 
[register fe 
Instruction decode 


Instruction register 
TAP 
controller 


Fig 8.2 A Block Schematic of the Test Logic 











Output 
buffer 






TDI 





8.3 Pin Functions 
There are four pins to be needed for this JTAG circuitry; TCK, TMS, TDI and 
TDO. 


The TCK pin can be used to provide the clock signal for only this JTAG 
circuitry. This clock signal is separated from the FDC system clocks in this 
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chip. 
The TMS pin can be used to define the operated TAP controller according to 
the value of this pin latched at the rising of the TCK pin. In addition, this pin 


is internally pulled up by the resistor with approximately from 50k Ohm to 
200k Ohm. 


The TDI can be used to transfer data into the internal registers implemented 
in this JTAG circuitry. This pin also internally pulled up by the resistor with 
approximately from 50k Ohm to 200k Ohm. 

The TDO can be used to be provided the output data from internal registers. 
The output signal is changed at the falling of the TCK pin. In addition, the 
output of this pin have three states; high, low and high impedance in logical 
states to be controlled by the TAP controller. 


8.4 Operations 


8.4.1 TAP Controller 


The TAP controller is a synchronous finite state machine that responds to 
changes at the TMS and TCK signals of the TAP and controls the sequence of 
operations of the circuitry defined by the IEEE standard 1149.1. 


8.4.1.1 TAP Controller State Diagram 


The state diagram for the TAP controller is as shown in Fig 8.4.-1. All state 
transitions of the TAP controller occurs based on the value of TMS at the 
time of a rising edge of TCK. Actions of Instruction, Boundary-Scan and 
Bypass registers occur on either the rising or the falling edge of TCK in each 
controller state as shown by Fig 8.4.-2. 
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Test-Logic 
~Reset 



















Select- 
IR-Scan 


Select- 
DR-Scan 


Run-Test/ 
Idle 

















0 
aa 
1 






Exitl-IR 


pr) 
Exit2-IR 
Update-IR 


0 


Exiti-DR 


Pause-DR 












Exit2-DR 








Update-DR 


NOTE: The value shown adjacent to each state transition in this 
figure represents the signal present at TMS at the time of a rising 
edqe at TCK. 









Fig 8.4-1 TAP Controller State Diagram 


180 


TCK 


State 


Actions occurring 
entered 


on the rising 
edge of TCK in 
the state 


Actions occurring 
on the fglling 
edge of TCK in 
the state 


Fig 8.4-2 TAP Controller State Diagram 
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HEAD 
Indicates the logical head number on the written data in media 
SECTOR 
Indicates the sector number 
BYTES/SECTOR (MFM) / FORMAT BYTE (GCR)” 
Code to indicate the data length in a sector (MFM). 
Code to indicate the data length in a sector (GCR). 
LAST SECTOR IN MULTI-SECTOR READ(or WRITE) 
Indicates the last sector number to be accessed on the track 
GAP3 (GAP3 Length) 
Indicates the number of bytes to be written in GAP3 
GSL (Gap3 Skip Length) 
Indicates the number of bytes to be skipped in GAP3 
DATA LENGTH IN BYTES 


Specifies the data length per sector to be accessed only when the 
“Number of data bytes in the sector” is set to 0 in the FM format. 


NCN (New Cylinder Number) 
Indicates the cylinder number being seeked 
PCN (Present Cylinder Number) 
Indicates the cylinder number where the read/write head is located 
ND (Non DMA transfer) 
When this bit is 1(high), Non-DMA transfer mode is specified. 
# SYNC GROUPS(GCR) 
Under Apple mode, specifies the number of the Self syne groups. 


PARAMETERS USED IN THE MFM AND FM FORMATS 

IAM is the special Address mark immediately after the Index 
position. 

SYNC is the bytes that the PLL needs to synchronize with the input 
data from FDD before FDC read the ID field or the Data field. 

IDAM is the special address mark in the ID field. 

DAM is the special address mark in the Data field. 

DDAM is the special address mark in the Data field, which is written by 
the Write Deleted Data. 

CRC is the Check Redundancy Cyclic bytes. 

Gap] is located between the "IAM" and the SYNC bytes in the first 
sector immediately after the Index position. 

Gap2 is located between the ID and Data fields. 

Gap3 is located between Sectors. 
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I——___—_—_———  |D field ———______—_- Gh ——————-—_ Data field ————_—_>- 


Syne Address address Syne data address 
byte mark header GAP2 1 byte mark ae ii 


OO TR PAU I [Gs S| | Oe Ae HE [eat BAN re | ee ee ee 


transfered data from this point from 


A 0 ID field —— ee Data fil ee 
Address address re self Sync byte data e Bit slip 






self Sync byte 





transfered data from this point from 
Fig. 4.18.2 Transferred Data for Dump After Specified ID Address Mark 


Read A Track 


_Phase_| Rw DY D6_Ds Dé D3 02 D1 Do 
| 


Command 








Cylinder 
Head 
Sector 
(Bytes/Sector) / Format Byte 
# of Sectors to be read 
GSL(MFM) / don't care (GCR) 
Data Length in Bytes 


+ 














status information 
after this command 







Status Regisiter 0 
Status Regisiter 1 
Status Regisiter 2 
Cylinder 
Head 
# of Sectors to be read 








FUNCTION 

Under Apple Mode: 
This command is similar to the Read Data command, except that this is a 
continuous read operation where the data field in each of the sectors is 
read. Unlike multi-sector reads with the Read Data command, this 
command will read the sectors as they are encountered on the disk. 
However, by this command, FDC can only read the media with the 
sector number in physically sequential order (like 1, 2, 3, 4, ....). So, in the 
case of interleaved media (like 1, 9, 2, 10, ....), the FDC can not read the 
sectors sequentially, but will read the sectors as they encounter, which 
will set ND bit (also see the description of Status Register 1 on p. 42). 
Immediately after finding the sector specified in the command phase, 
the FDC starts reading all data fields on the track as continuous blocks of 
data. Even if the FDC finds an error in the Address header or Data 
Checksum bytes, it will continue to read the data from the track, but will 
mark the error in the Status register 0-2 in the result phase. 


This command terminates when the number of sectors read is equal to 
the number specified in the command phase. 
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Seek 


Command 0 0 0 0 command ade 
X X X X i Sloeieee 
Head is positioned } 
over specified cylinder. 


New CylinderNumber 
FUNCTION 


This command causes the FDD to retract the Read/Write head to the 
cylinder to be programmed in the “New cylinder Number" byte. 






Under Apple mode: 
The FDC executes this command by issuing the /Step command to the 
FDD. To determine that the /Step command has completed, the FDC 
reads the /Ready status line from the FDD. This provides a full 
handshake for the step operation. The following conditions are not 
supported by this command: 
- Seek with no media installed 
- Seek on more than one drive simultaneously 
- Check status of the /DIRTIN signal during the seek operation 


Under Standard modes: 

The FDC operates this command if the internal parameter of "PCN" is 

not equivalent to the "New Cylinder Number"(NCN). 

When NCN > PCN: 
The DIR_B signal in the drive interface becomes active low and 
then the required number of the step pulses are issued to the 
FDD and the number of this PCN will be incremented per step 
pulse. 

When NCN < PCN; 
The DIR_B signal in the drive interface becomes inactive high 
and then the required number of the step pulses are issued to the 
FDD and finally the number of this PCN will be decremented per 
step pulse. 


The interval time between the step pulses should set by the Step rate 
parameter in the Specify command. When PCN becomes equal to 
NCN, the SE bit in the Status register 0 is set and the FDC interrupts to 
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Select Drive Type 


|_erase_| nl 7 06 ps 04 ps pe pr 00 oo | _romatis 


command | commandcode _—si| 


xX po | Echo back for this 


FUNCTION 
The Select Drive Type command selects the type of drive that the next 
command: will be executed on. 


POA IO POD 
| 0 | 0 | Conventional FDD ( Reset Default ) FDD =<4MB 


Te + | ser 


RESERVED 


da pom 
ects Aa APPLE FDD 
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The timing of SPECIFY command is shown in Fig.5.1-4. This command 
has only Command phase. The command codes, (SRT/HUT, and HLT 
under only Standard modes) and ND are written to the FDC in that order, 
and command execution terminates. 


The timing of the SEEK and RECALIBRATE commands are shown in 
Fig.5.1-5. However, for the RECALIBRATE command the cylinder number 
to be sought is fixed (cylinder 0), and therefore the NCN parameter is not 
necessary. For either command, when the seeking operation to the desired 
location is confirmed, the FDC outputs the INT signal to the host to 
inform that seek operation is completed. In addition, these commands 
differ from other commands in that they have no Resultant phase. 
Consequently, result status are output in the R-phase of the SENSE 
INTERRUPT STATUS command given after the INT signal is confirmed. 


The timing of the SENSE INTERRUPT STATUS command is shown in 
Fig.5.1-6. When the INT signal is output from the FDC and bit 4 (FDC 
Busy) of the status register is 0, this command checks the cause of the 
interrupt request. When this command is written, the FDC resets the 
ROM bit and INT signal and enters R-phase. The status at the time the 
interrupt is generated can be found by reading the contents of the STO and 
the PCN in the R- phase of this command. 


The timing of the INVALID command is shown in Fig.5.1-10. The Invalid 
command is activated when either of the following occurs; 


elf a command code not defined as a valid command is written in 
Command phase. 


elf the SENSE INTERRUPT STATUS command is written but the 
cause of the interrupt no longer remains. 


In either instance, 80(16) is set to the STO register to be read in Resultant 
phase as an invalid command and the FDC waits for the next command. 


5.1.2 FIFO Operations 


The FDC has the FIFO and all the data transfer can go through the FIFO. The 
FIFO is 16 bytes in size and programmable threshold value. In this 
description, "threshold" is defined as the number of available bytes to the 
FDC until the HOST starts the service from the FDC request, and range from 1 
to 16. The threshold parameter which the user programs is one less and range 
from 0 to 15. The FDC can support the single and demand transfer. After a 
reset, the FIFO is no available. This reset default is changed by issued 
"CONFIGURE" command, and the FIFO operation becomes available with 
threshold control. The effectivity of FIFO is that it can allow the system a 
larger DMA latency without causing a overrun/underrun error. 


In command phase, the command and their parameters must be sent by 
checking RQM=1 and DIO=1 of status register. After receives all 
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MAX SERVICE DELAY 
The service latency is defined by the following formula: 
Delay = Threshold x (8bits/data rate)-12 x internal clock period 


for example Threshold = 8 bytes Data Rate=0.5Mbps 
from HOST to FDC 


8byte x (8bits/0.5p1sec) -12x0.125usec = 126.6uSec 


5.1.2.2 DMA Modes 
There are two DMA Data Transfer modes: 
(1) Single Transfer mode 
(2) Demand Transfer mode 


DMARQ / A gee A\_ 


park BO LO LIL Per 
RWRB ra ee eS 


Single Transfer Mode 


Oe Rr 
DMAAK_B ~—\ [~~ / 


FO_BOWF_®)—UUL— 


Demand Transfer Mode 
Fig. 5.1.2.1 Host Interface During the DMA transfers 


Data Transfers from FDC to HOST 


When the number of bytes in FIFO is less than or equal to <16 - threshold>, a 
DMARQ is activated. By the FDC request, a DMA controller starts data 
transfer from FIFO to HOST. The FDC will deactivate the DMARQ when 
FIFO becomes empty. DMARQ goes inactive after DMAAK goes active for the 
last byte of a data transfer (in DMA controller's single transfer mode) or on 
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the active edge of RD_B on the last byte( in DMA controller's demand 
transfer mode). 


DataTransfers from HOST to FDC 


When then number of bytes in FIFO is greater than of equal to <threshold>, a 
DMARQ is actives. By the FDC request, a DMA controller starts data transfer 
from HOST to FIFO. The FDC will deactivate the DMARQ when FIFO become 
full. DMARQ goes inactive after DMAAK goes active for the last byte of a data 
transfer (in DMA controller's single transfer mode) or on the active edge of 
WR_B the last byte(in DMA controller's demand transfer mode). 


5.13 Non-DMA mode 
Data Transfers from FDC to HOST 


The INT and RQM bit in the Main Status Register are activated when the 
number of bytes in FIFO is less than or equal to the <16-threshold>. The 
HOST must start to read the data from the FIFO by request the FDC, and 
repeat until the data in the FIFO is empty. The FDC will deactivate the INT 
and ROM bit when the FIFO becomes empty. 


Data Transfers from HOST to FDC 


The INT and ROM bit in the Main Status Register are activated when the 
number of bytes in FIFO is greater than or equal to the <threshold>. The 
HOST must start to write the data to the FIFO by request the FDC, and repeat 
until the data in FIFO are full. The FDC will deactivate the INT and the RQM 
bit when the FIFO becomes full. 
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Command 


E-phase 


C-phase 


wait 
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: 


Command 


Fig.5.1-2 WRITE DATA, FORMAT A TRACK, and FORMAT/WRITE commands 
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OcT 


Note *1 *4 
ENBL_B 
RDATA_B RDDATA (csTIN /READY 


LSTRB 


WGATE_B 
WDATA_B 
address 
header 
GCA eynel | [ [syne | [[tg Data [Tov 
Track format AM cksm DM cks 
bit slip bit slip 
wu Free [ol [oor Bad | ome I] ov 
AM CRC DM CRC 


Note *1 : This signal can be controlled by the only "Set Enable Control" command. 


Fig.5.2-1 READ DATA, READ ID, READ A TRACK, and RAW DUMP 


Fig.5.2-7 Disable/Enable DPLL 


: Note *1 
ENBL_B8 


SEL, CAO-2 X DP 


RDATA_B 


LSTRB | | ; 


/DPLL 








Note *1 : This signal can be controlled by the only "Set Enable Control" command. 


Fig.5.2-8 SET DRIVE MODE 


Note *1 " “4 


ENBL_B 


SEL, CA0-2 iFM mode)X mode IREADY 


RDATA_B IREADY 


LSTRB | | 


/MFM mode 
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Fig.5.2-9 SET MOTOR CONTROL for Motor ON 


ENBL_B 


SEL, CA0-2 \voTor on IREADY 
LSTRB | | 


{MOTOR ON 





Note “1: This signal can be controlled by the only “Set Enable Control" command. 


Fig.5.2-10 EJECT 


Note *1 ' Note "1 


ENBL_B | | 


RDATA_B 


LSTRB | | 


EJECT 
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Chapter 6 Firmware Flowcharts 


Under Apple mode, abstract firmware algorithms for each command are 
shown at the following pages. 


Under Standard modes, the abstract firmware algorithms are the same as that 
of the pPD765A. 
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CONFIGURE 


Receives parameters 
- EFIFO 
- FIFOTHR 
-PRETRK 











DISABLE/ENABLE DPLL 


Disable/Enable DPL 










Set INT 





EJECT DISK 
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FORMAT A TRACK (MFM Format) 


FORMAT A TRAC 
Receives HD, DR 










Preamble formatting 


Set AT, NR 
- SYNC 
- INDEX Address Mark <—/CsTIN—> 
Set AT, FIN 









- SYNC 
- ID address mark 
-ID 


- Data address mark 
- Data 


Abnormal 
termination 


<— READY > 


Set INT signal 
Send Result status 
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READ ID (GCR Format) 


READ ID 

Receives HD, DR 
<< READY > N 
<AM detect > 








Set AT, FIN 
Read ID 4 2 





<I detected7 => Abnormal 


termination 


N 


<—— READY > 
Lees 


Set INT signal 
end result status 
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Fig.8 MFM FDD Control Timing 


Fig. 9 Negative Reset 
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